Gevent中信号量的使用

Posted 程序猿终结者

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Gevent中信号量的使用相关的知识,希望对你有一定的参考价值。

  greenlet间同步方法:信号量

  1.为什么引入信号量;

  2.gevent信号量有哪些;

  3.编程实现。

  为何引入信号量

  信号量是一个允许Greenlet相互合作,限制并发访问或运行的低层次的同步原语。

  什么是信号量

  1.信号量有两个方法

  acquirerelease。在信号量是否已经被 acquirerelease,和拥有资源的数量之间不同,被称为此信号量的范围。如果一个信号量的范围已经降低到0,它会阻塞acquire操作直到另一个已经获得信号量的greenlet作出释放。

  2.Gevent信号量

  1Semaphore(也被称为锁);

  2BoundedSemaphore

  3)二者联系与区别。

  编程实例

  import gevent

  from gevent.pool import Pool

  from gevent.lock import BoundedSemaphore

  sem = BoundedSemaphore(1)

  def worker1(n):

  sem.acquire()

  print(\'worker %d acquire sem\' %n)

  gevent.sleep(0)

  sem.release()

  print(\'woker %d release sem\' %n)

  def worker2 ( n ) :

  with sem:

  print( \' worker %d acquire sem\' %n )

  gevent.sleep( 0 )

  print( \' woker %d release sem \' %n )

  pool = Pool()

  pool.map( worker2 , xrange ( 0 ,5 ) )

  执行结果:

 

 

原文链接:http://www.maiziedu.com/wiki/frame/amount/

以上是关于Gevent中信号量的使用的主要内容,如果未能解决你的问题,请参考以下文章

Linux中IPC信号量的使用

Linux中信号量处理

pthreads互斥与信号量

生产者消费者仅使用1个额外的信号量

如何正确销毁 C 中多个进程使用的共享未命名信号量?

FreeRTOS 信号量