信号量
线程信号量的使用方法和进程是一致的,决定了同一时间能运行的代码的的数量
from threading import Semaphore,Thread
from time import sleep
def func1(sem,i):
sem.acquire()
sleep(1)
print("线程信号量")
n = i + 3
print(n)
sem.release()
if __name__ == '__main__':
sem = Semaphore(4)
for i in range(8):
t = Thread(target=func1,args=(sem,i))
t.start()
事件
多线程的事件的使用方法和多进程是一样的,用法可以参考多进程编程-事件那一篇
下面的例子我们模拟一个数据库的连接过程,先启动一个子线程来判断网络是否联通,如果联通则放行,不然就进行堵塞。
from threading import Event,Thread
from time import sleep
import random
def check_net(e):
sleep(random.randint(0,5))
e.set()
def conn(e):
count = 0
while count < 3:
e.wait(1)
if e.is_set() == True:
print("数据库连接成功")
break
else:
count += 1
print("网络超时,连接失败")
if count == 3:
raise TimeoutError("网络连接超时,退出")
if __name__ == '__main__':
e = Event()
t1 = Thread(target=check_net,args=(e,))
t2 = Thread(target=conn,args=(e,))
t1.start()
t2.start()