`
iyuan
  • 浏览: 463225 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

gevent 任务的持续追加和执行(续·真)

阅读更多
之前写过一篇通过队列、池来持续追加任务的方式:http://iyuan.iteye.com/blog/781168

今个儿重新咀嚼了下,发现gevent的pool似乎可以达到真正意义上的任务追加。

这里先重新简单的阐明下“任务”这个概念,相对于上次那篇,相对宏观了些:
就是Greenlet!(不熟悉的可以参看下gevent的文档http://www.gevent.org/contents.html)

先实例化:
g = pool.Pool()

通过g.add(),g.spawn(),就可以持续追加任务入池,在建立pool时,可以设置size,不过这里似乎有个bug,设定了size后,似乎不能在子任务中再添加新任务进任务表。

下面给个demo:
from gevent import pool
g = pool.Pool()
def a():
    for i in xrange(100):
        g.spawn(b)
def b():
    print 'b'
g.spawn(a)
g.join()


相较于上次那篇,可以做更繁复的事了,不过,根本上而言,一次做一件事 才是王道啊。

0
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics