码迷,mamicode.com
首页 > 其他好文 > 详细

Gevent中信号量的使用

时间:2016-12-20 20:36:37      阅读:156      评论:0      收藏:0      [点我收藏+]

标签:分享   amount   range   合作   1.5   frame   image   print   port   

  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中信号量的使用

标签:分享   amount   range   合作   1.5   frame   image   print   port   

原文地址:http://www.cnblogs.com/space007/p/6203783.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!