资讯专栏INFORMATION COLUMN

Python线程专题5:信号量与有边界的信号量

Dionysus_go / 2865人阅读

摘要:有边界的信号量语法创建一个新的有边界信号量。是计数器的初始值,如果忽略,将默认为信号量与有边界的信号量的区别的工作方式与完全相同,但操作的次数不能超过的操作次数。信号量与互斥锁的微妙差别信号量可用于发送信号。

上一篇文章:Python线程专题4:Timer对象、Lock对象、Rlock对象
下一篇文章:Python线程专题6:事件
信号量与有边界的信号量
信号量是一个基于计数器的同步原语,每次调用acquire()方法时,此计数器减1,每次调用release()方法时此计数器加1.。如果计数器为0,acquire()方法将会阻塞,直到有其他线程调用release()方法为止。
信号量
语法:
s=Semqphore(value)
创建一个新的信号量。value是计数器的初始值。如果省略value,将默认设置为1
常用方法:
s.acquire(blocking):获取信号量。如果内部计数器大于0,此方法将把它的值减1。
然后立即返回。如果它的值为0,此方法将阻塞,直到另一个线程调用release()方法为止。
blocking参数的行为与Lock和RLock对象中描述的相同。

s.release():通过将内部计数器的值加1来释放一个信号量。
如果计数器为0,而且另一个线程正在等待,该线程讲被唤醒。
如果有多个线程正在等待,只能从它的acquire()的调用中返回一个,并且顺序不确定。
有边界的信号量
语法:
bs=BoundedSemaphore(value)
创建一个新的有边界信号量。value是计数器的初始值,如果忽略,将默认为1.
信号量与有边界的信号量的区别
BoundedSemaphore的工作方式与Semaphore完全相同,但release()操作的次数不能超过acquire()的操作次数。
信号量与互斥锁的微妙差别
信号量可用于发送信号。例如,可以从不同线程调用acquire()和release()方法,以便在生产者和消费者线程之间进行通信。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/42391.html

相关文章

  • Python线程专题纵览篇

    摘要:上一篇文章进程专题完结篇多进程处理的一般建议下一篇文章线程专题多线程使用的必要性进程线程进程能够完成多任务,比如在一个电脑上可以运行多个软件。由于占用资源少,也使得多线程程序并发比较高。 上一篇文章:Python进程专题完结篇:多进程处理的一般建议下一篇文章:Python线程专题1:多线程使用的必要性 进程VS线程 进程:能够完成多任务,比如在一个电脑上可以运行多个软件。线程:也能够...

    张红新 评论0 收藏0
  • Python线程专题6:事件

    摘要:上一篇文章线程专题信号量与有边界的信号量下一篇文章线程专题条件变量事件用于在线程之间通信。一个线程发送事件信号,一个或多个其他线程等待它。阻塞直到内部标志为。最坏的情况是,由于事件信号丢失,整个程序将会挂起。 上一篇文章:Python线程专题5:信号量与有边界的信号量下一篇文章:Python线程专题7:条件变量事件用于在线程之间通信。一个线程发送【事件】信号,一个或多个其他线程等待它。...

    huhud 评论0 收藏0
  • Python线程专题4:Timer对象、Lock对象、Rlock对象

    摘要:语法创建定时器对象,在秒后运行函数,和提供传递给的参数和关键字参数。在调用方法后才能启动计定时器。如果函数还未执行,取消定时器。否则,锁将保持已锁定状态。 上一篇文章:Python线程专题3:thread对象下一篇文章:Python线程专题5:信号量与有边界的信号量 Timer对象、Lock对象、Rlock对象 Timer对象 Timer对象用于在稍后的某个时间执行一个函数。 语法:...

    Edison 评论0 收藏0
  • Python进程专题6:共享数据与同步

    摘要:可以使用标准的索引切片迭代操作访问它,其中每项操作均锁进程同步,对于字节字符串,还具有属性,可以把整个数组当做一个字符串进行访问。当所编写的程序必须一次性操作大量的数组项时,如果同时使用这种数据类型和用于同步的单独大的锁,性能将极大提升。 上一篇文章:Python进程专题5:进程间通信下一篇文章:Python进程专题7:托管对象 我们现在知道,进程之间彼此是孤立的,唯一通信的方式是队...

    Yuanf 评论0 收藏0
  • Python进程专题5:进程间通信

    摘要:上一篇文章进程专题进程池下一篇文章进程专题共享数据与同步模块支持的进程间通信主要有两种管道和队列。队列底层使用管道和锁,同时运行支持线程讲队列中的数据传输到底层管道中,来实习进程间通信。 上一篇文章:Python进程专题4:进程池Pool下一篇文章:Python进程专题6:共享数据与同步 multiprocessing模块支持的进程间通信主要有两种:管道和队列。一般来说,发送较少的大...

    eccozhou 评论0 收藏0

发表评论

0条评论

Dionysus_go

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<