zoukankan      html  css  js  c++  java
  • 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/

  • 相关阅读:
    模拟100 题解
    模拟99 题解
    模拟98 题解
    模拟97 题解
    模拟96 题解
    模拟95 题解
    模拟94 题解
    模拟93 题解
    模拟92 题解
    Django-- 多数据库联用
  • 原文地址:https://www.cnblogs.com/space007/p/6203783.html
Copyright © 2011-2022 走看看