Python多线程编程非常类似于linux C的pthread多线程库,只不过以面向对象的形式提供。Cpython 由于解释器实现策略的问题,增加了GIL(Global Interpreter Lock)全局解释器锁,使得python多线程在同一时刻只能有一个线程执行。因此,在使用Cpython时,对于CPU密集型任务,我们最好不采用python多线程方案,而是使用多进程方案。但对于IO密集型任务,由于每次进行IO的时候,python会释放GIL锁,多线程方案还是可取的。
python的多线程是封装在threading模块中的,有两种方式编写多线程程序,一种是创建一个Thread对象,然后调用对象的start()方法,另一种是继承Thread类,然后重写run()方法。
创建Thread类对象的示例代码如下:
importos, sys
importthreading
importtime
defmy_thread(someone):
print('[{}]: {} begin working'.format(threading.currentThread(), someone))
time.sleep(2)
print('[{}]: {} finished working'.format(threading.currentThread(), someone))
if__name__ == '__main__':
t1 = threading.Thread(target= my_thread, args= ('Jack',))
t2 = threading