python中的公平信号量

是否有可能在python中有一个公平的信号量,一个保证阻塞线程按照他们调用acquire()的顺序解除阻塞的信号量?

解决方法:

您可能必须从其他移动部件构建一个.例如,创建一个Queue.Queue(),每个侦听器都会在其上发布一个全新的Event(),然后等待它.当需要唤醒其中一个等待线程时,弹出队列上等待时间最长的项目 – 它将是其中一个事件对象 – 并通过event.set()释放该线程.

显然,你也可以在每个等待进程中使用一个信号量,但我喜欢Event的语义,因为它只能发生一次,而信号量的语义是它的值可以支持许多等待的线程.

要设置系统:

import Queue
big_queue = Queue.Queue()

然后,等待:

import threading
myevent = threading.Event()
big_queue.put(myevent)
myevent.wait()

并释放一个等待线程:

event = big_queue.get()
event.set()

我认为这种方法的弱点在于执行set / release的线程必须等待等待的线程出现,而真正的信号量会让几个版本继续进行,即使没有人在等待吗?

上一篇:java-从多个线程调用时Thread.sleep()如何工作


下一篇:java – ImageIO已同步