直接学习:https://edu.csdn.net/course/play/24756/284632
condition 版本的生产者与消费者模式:
Lock版本的生产者与消费者模式的一个弊端是在消费者中,总是通过while true死循环并且上锁的方式去判断钱够不够。频繁上锁很耗CPU资源。condition 版本的生产者与消费者模式解决了以上弊端,它通过threading.Condition来实现。threading.Condition可以在没有数据的时候处于阻塞状态,一旦有合适的数据了,可是使用notify相关函数通知处于等待状态中的线程,这样就可以省去一些无用的上锁解锁操作,可以提高程序的性能。
以下将一些常用函数做一些介绍:
1、acquire 上锁
2、release 解锁
3、wait 当前线程处于等待状态,并且会释放锁。可以被其他线程使用notify和notify_all函数唤醒。被唤醒后会继续等待上锁,上锁后执行下面的代码。
4、notify 通知某个等待的线程。默认第一个等待的线程。notify_all:通知所有正在等待的线程,notify和notify_all不会释放锁,并且需要在release之前调用。
示例代码如下:
import threading
import random
import time
gMoney = 0
gTime =0
gCondition = threading.Condition()
class Producer(threading.Thread):
def run(self):
global gMoney
global gTime
while True:
gCondition.acquire()
if gTime >=10:
gCondition.release()
break
money = random.randint(0,100)
gMoney += money
gTime += 1
print("%s生产了%d元钱,剩余%d元钱"%(threading.current_thread().name,money,gMoney))
gCondition.notify_all()
gCondition.release()
time.sleep(1)
class Consumer(threading.Thread):
def run(self):
global gMoney
global gTime
while True:
gCondition.acquire()
money = random.randint(0,100)
while gMoney< money:
if gTime >=10:
print("%s想消费%d元钱,但是余额只有%d元钱了,并且生产者已经不再生产了!"%(threading.current_thread().name,money,gMoney))
gCondition.release()
return
print("%s想消费%d元钱,但是余额只有%d元钱了,消费失败!"%(threading.current_thread().name,money,gMoney))
gCondition.wait()
gMoney -= money
print("%s消费了%d元钱,剩余%d元钱"%(threading.current_thread().name,money,gMoney))
gCondition.release()
time.sleep(1)
def main():
for x in range(5):
th = Producer(name = "生产者%d号"% x)
th.start()
for x in range(5):
th = Consumer(name = "消费者%d号"% x)
th.start()
if __name__ == "__main__":
main()