event是类似于java中的等待唤醒机制,具体方法参照上一篇CSDN
https://blog.csdn.net/qq_41901915/article/details/82703429
下面来介绍开启线程的第一种方式
#Filename:threading1.py
#开启线程的第一种方式
import threading
import time
event=threading.Event()
event.set()
def run(n):
event.wait()
event.clear()
print('task',n)
time.sleep(2)
event.set()
t1=threading.Thread(target=run,args=('t1',))#指定一个目标,指定对应的参数
t2=threading.Thread(target=run,args=('t2',))#注意后边的逗号不可省略
t1.start()
t2.start()
结果:
>>> task t1
task t2
如果没有加入event的话,会出现乱码的现象,我们把event注释之后得到的结果为:
#Filename:threading1.py
#开启线程的第一种方式
import threading
import time
#event=threading.Event()
#event.set()
def run(n):
# event.wait()
# event.clear()
print('task',n)
time.sleep(2)
# event.set()
t1=threading.Thread(target=run,args=('t1',))
t2=threading.Thread(target=run,args=('t2',))
t1.start()
t2.start()
结果:
>>> tasktask t1t2
下面来介绍开启线程的第二种方式
#Filename:threading2.py
#开启线程的第二种方式,继承的方式
import threading
event=threading.Event()
event.set()
class mythread(threading.Thread):#继承自threading.Thread
def __init__(self,n):#初始化
super(mythread,self).__init__()#调用父类的初始化
self.n=n
def run(self):
event.wait()
event.clear()
print('run task',self.n)
event.set()
t1=mythread('t1')
t2=mythread('t2')
t1.start()
t2.start()
结果:
>>> run task t1
run task t2