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

被折叠的 条评论
为什么被折叠?



