Python拓展14(Semphore带计数的线程同步机制)

本文介绍了Python中Semaphore和BoundedSemaphore的区别。Semaphore是一种带计数的线程同步机制,而BoundedSemaphore则在此基础上增加了计数上限的限制。通过示例代码展示了这两种同步机制的使用方法。

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

Semphore同步  

  Semphore,是一种带计数的线程同步机制,当调用release时,增加计算,当acquire时,减少计数,当计数为0时,自动阻塞,等待release被调用。

而在Python中存在两种Semphore,一种就是纯粹的Semphore,还有一种就是BoundedSemaphore。

区别:

  Semphore:  在调用release()函数时,不会检查,增加的计数是否超过上限(没有上限,会一直上升)

  BoundedSemaphore:在调用release()函数时,会检查,增加的计数是否超过上限,这样就保证了使用的计数

 

import threading
import time

semaphore = threading.Semaphore(3)
#semaphore = threading.BoundedSemaphore(3)

def fun():
    print "Thread %s is waiting semphore\n" % threading.currentThread().getName()
    semaphore.acquire()
    print "Thread %s get semphore\n" % threading.currentThread().getName()
    time.sleep(1)
    print "Thread %s release semphore\n" % threading.currentThread().getName()
    semaphore.release()


if __name__ == "__main__":
    t1 = threading.Thread(target=fun)
    t2 = threading.Thread(target=fun)
    t3 = threading.Thread(target=fun)
    t4 = threading.Thread(target=fun)

    t1.start()
    t2.start()
    t3.start()
    t4.start()

    t1.join()
    t2.join()
    t3.join()
    t4.join()

    semaphore.release()  #这里因为是简单的Semaphore,所以可以再次释放,不会报错,而BoundedSemaphore,则会报错

 

转载于:https://www.cnblogs.com/L5251/articles/9463695.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值