python中多线程开启的两种方式(内含有event的应用,即安全的机制,类似于java的等待唤醒机制,不会出现多个线程之间的错乱问题)

 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

猜你喜欢

转载自blog.csdn.net/qq_41901915/article/details/82729377
今日推荐