简单的解决方案
import threadingdef work (): threading.Timer(0.25, work).start () print "stackoverflow"work ()
上面的代码可以确保
work以每秒四次的间隔运行,其背后的理论是它将 “排队” 对自己的呼叫,该呼叫将在未来 0.25
秒内运行,而不会等待发生这种情况。
因此,它几乎可以不间断地完成工作,并且我们非常接近每秒精确执行4次该功能。
threading.Timer通过以下指向python文档的链接可以阅读更多信息:
- docs.python.org-16.2.7。 计时器对象
推荐]更高级/动态的解决方案
即使先前的函数按预期工作,您也可以创建一个辅助函数来帮助处理将来的定时事件。
下面的内容对于该示例来说足够了,希望代码能说明一切-它不像看起来的那样先进。
当您可以实现自己的包装程序来满足自己的确切需求时,可以将其视为一种启发。
import threadingdef do_every (interval, worker_func, iterations = 0): if iterations != 1: threading.Timer ( interval, do_every, [interval, worker_func, 0 if iterations == 0 else iterations-1] ).start () worker_func ()def print_hw (): print "hello world"def print_so (): print "stackoverflow"# call print_so every second, 5 times totaldo_every (1, print_so, 5)# call print_hw two times per second, foreverdo_every (0.5, print_hw)



