第十四章:应用构建模块-sched:定时事件调度器-重叠事件

14.11.2 重叠事件
run()调用会阻塞,直至所有事件都已经被处理。每个事件在相同的线程中运行,所以如果一个事件需要很长事件运行,并且超出了事件之间的延迟,那么就会出现重叠。重叠可以通过推迟后面的事件来解决。这样不会丢失事件,但有些事件可能比其调度时间更晚调用。在下面的例子中,long_event()调用sleep休眠,不过也可以完成一个长时间计算或者在I/O上阻塞,这样也能很容易地延迟处理。

import sched
import time

scheduler = sched.scheduler(time.time,time.sleep)


def long_event(name):
    print('BEGIN EVENT :',time.ctime(time.time()),name)
    time.sleep(2)
    print('FINISH EVENT:',time.ctime(time.time()),name)

print('START:',time.ctime(time.time()))
scheduler.enter(2,1,long_event,('first',))
scheduler.enter(3,1,long_event,('seconod',))

scheduler.run()

其结果是第一个事件一旦完成就会立即运行第二个事件,因为第一个事件花费的时间足够长,使时钟超过了第二个事件期望的开始时间。
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_43193719/article/details/94654219