Gevent中信号量的使用

时间:2021-12-13 05:19:53

  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 ) )

  执行结果:

Gevent中信号量的使用 

 

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