第五章:爬虫进阶-condition 版本的生产者与消费者模式

直接学习: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()           
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值