一、python线程
线程是任务调动和执行的最小单位。python的线程操作使用的threading模块,Thread 是threading模块中的类,可以使用它来创建线程。有两种方式来创建线程:本文是通过继承Thread类,重写它的run方法来实现。
二、重写threading.Thread
threading.Thread无法获取返回值,需要重写获得返回值,当程序中的一些模块之间互相独立时可以使用多线程执行各个模块节省时间,假设请求a、b两个接口,时间分别要2秒、4秒,流水线执行时a---->b一共执行完需要6秒,使用多线程执行的话ab并行请求,只需要4秒。
代码如下:
import time
import threading
class Mytest1(threading.Thread):
def __init__(self):
super().__init__()
def run(self):
print('1', time.time()) # 记录执行时间
time.sleep(5) # 等待5秒
self.a = 1
def get_test1(self):
threading.Thread.join(self)
return self.a
class Mytest2(threading.Thread):
def __init__(self):
super().__init__()
def run(self):
print('2', time.time()) # 记录执行时间
time.sleep(2)
self.a = 2
def get_test2(self):
threading.Thread.join(self) # 线程等待
return self.a
if __name__ == "__main__":
t1 = Mytest1()
t1.start()
t2 = Mytest2()
t2.start()
print(time.time())
print('<<<<<<<返回结果', t1.get_test1()) # 获取结果
print('<<<<<<<返回结果', t2.get_test2())
print(time.time())
打印结果:
1 2 1665302252.9814034
1665302252.981493
1665302252.9811752
<<<<<<<返回结果 1
<<<<<<<返回结果 2
1665302257.986735
如果注释掉get_test1中的threading.Thread.join(self) 程序报错
AttributeError: ‘Mytest1’ object has no attribute ‘a’
三、结果分析
从结果可以观察到,两个模块的执行基本是同时进行的,Mytest1类中等待了5秒,Mytest2类中等待了2秒,最后整个程序结束大致花费5秒钟时间。注意当获取返回值时候一定要join等待,否则相当于run方法执行立刻取值,但此时方法还没有返回这个值,这时候就会报错。