Python学习笔记——多线程编程(三)

本文介绍信号量的概念,包括计数器的工作原理及其在资源消耗与释放中的作用。通过对比Semaphore与BoundedSemaphore的区别,重点讲解有界信号量如何避免计数器超出初始值的情况。并提供了一个使用Python实现的糖果机示例,展示如何利用锁和信号量来同步多个线程,以实现资源的有序生产和消费。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

@信号量
    #是一个计数器,当资源消耗时递减,当资源释放时递增。
 
@两种信号量类
    #Semaphore
    #BoundedSemaphore, 一个有界信号量会确保它当前的值不超过它的初始值。如果超过,则引发ValueError。
 
@事例:
    #!/usr/bin/env python
 
    from atexit import register
    from random import randrange
    from threading import BoundedSemaphore, Lock, Thread
    from time import sleep, ctime
 
    lock = Lock()
    MAX = 5
    candytray = BoundedSemaphore(MAX)
 
    def refill():
        lock.acquire()
        print("Refilling candy...")
        try:
            candytray.release()
        except ValueError:
            print('full, skipping')
        else:
            print('OK')
        lock.release()
 
    def buy():
        lock.acquire()
        print('Buying candy...')
        if candytray.acquire(False):
            print('OK')
        else:
            print('empty, skipping')
        lock.release()
 
    def producer(loops):
        for i in range(loops):
            refill()
            sleep(randrange(3))
 
    def consumer(loops):
        for i in range(loops):
            buy()
            sleep(randrange(3))
 
    def _main():
        print('starting at:', ctime())
        nloops = randrange(2, 6)
        print('THE CANDY MACHINE (full with %d bars)!' % MAX)
        Thread(target=consumer, args=(randrange(nloops, nloops+ MAX + 2),)).start()
        Thread(target=producer, args=(nloops,)).start()
 
    @register
    def _atexit():
        print('all DONE at:', ctime())
 
    if __name__ == '__main__':
        _main()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值