首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在线程中使用LoopingCall?

如何在线程中使用LoopingCall?
EN

Stack Overflow用户
提问于 2011-08-28 07:46:44
回答 1查看 2.3K关注 0票数 3

我有一个简单的例子:

代码语言:javascript
复制
from twisted.internet import utils, reactor
from twisted.internet import defer
from twisted.internet import threads
from twisted.internet.task import LoopingCall,deferLater
import time

def test1():
    print 'test'

def test2(res):
       l = []
       for i in xrange(3):
           l.append(threads.deferToThread(test4))
       return defer.DeferredList(l)

def test3(res):
    pass

def test4():
    print 'thread start'
    time.sleep(10)
    print 'thread stop'


def loop():
    d = defer.maybeDeferred(test1)
    d = d.addCallback(test2)
    d.addCallback(test3)

LoopingCall(loop).start(2)

reactor.run()

这是不正确的剧本。我想:

代码语言:javascript
复制
1) print 'test'
2) start 3 threads, waiting while all threads stops
3) sleep 2 seconds 
4) repeat
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-08-28 08:49:08

LoopingCall将每隔N秒运行您传递给它的callable,其中N是您传递给start的编号。它不会在上一次调用结束后等待N秒,而是在上一次调用开始后等待N秒。换句话说,它尝试停留在由N和开始时间定义的间隔上,以N秒、N*2秒、N*3秒等时间运行呼叫。

如果进程太忙而无法进行其中一个调用,它将跳过该迭代。如果调用返回延迟,并且到下一个时间间隔还没有触发延迟,它将跳过该迭代。

因此,您可以通过在loop的末尾返回d来更接近您想要的行为,但是LoopingCall不会总是在延迟触发后等待2秒。它将等待下一个N秒的倍数,从开始时间开始计数,然后再次调用函数。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7218108

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档