【Python3 爬虫】U23_多线程爬虫之初识多线程

1.什么是"多线程"?

多线程是为了同步完成多项任务,通过提高资源使用效率来提高系统的效率。线程是在同一时间需要完成多项任务的时候实现的。举个最简单的例子说明:多线程就像火车的每一个车厢,而进程则是火车。
并发:指的是任务数多余cpu核数,通过操作系统的各种任务调度算法,实现用多个任务“一起”执行(实际上总有一些任务不在执行,因为切换任务的速度相当快,看上去一起执行而已)。
并行:指的是任务数小于等于cpu核数,即任务真的是一起执行的。

2.threading模块

Python中的threading模块是专门用来做多线程编程的,threading模块中最常用的类是Thread,下面是一个简单的小案例:
以下是一个跳舞、唱歌的场景,某人可以先跳会舞,再唱会歌,但是为了节省时间,他也可以一边跳舞一边唱歌。
不使用多线程

import time
def dance():
    # 跳舞5s中
    for x in range(1,6):
        print('我正在跳舞,%s秒' %x)
        time.sleep(1)

def sing():
    # 唱歌5s中
    for x in range(1,6):
        print('我正在唱歌,%s秒' %x)
        time.sleep(1)
def main():
    dance()
    sing()

if __name__ == '__main__':
    main()

打印结果:

使用多线程

import threading
import time
def dance():
    # 跳舞5s中
    for x in range(1,6):
        print('我正在跳舞,%s秒' %x)
        time.sleep(1)

def sing():
    # 唱歌5s中
    for x in range(1,6):
        print('我正在唱歌,%s秒' %x)
        time.sleep(1)
def main():
    t1 = threading.Thread(target=dance)
    t2 = threading.Thread(target=sing)

    t1.start()
    t2.start()

if __name__ == '__main__':
    main()

打印结果:

posted @ 2020-04-04 14:51  OLIVER_QIN  阅读(246)  评论(0编辑  收藏  举报