Timer.periodic 构造函数
创建一个新的重复计时器。
callback
会以 duration
间隔反复调用,直到使用 cancel 函数取消。
确切的时间取决于底层计时器实现。在 duration * n
时间内不会调用超过 n
次回调,但两次连续回调之间的时间可以比 duration
短或长。
特别是,实现可能安排下一个回调,例如,在之前的回调结束时、开始时或计划时(即使实际的回调被延迟)之后的 duration
时间内。
负的 duration
被视为与 Duration.zero 相同。
示例
var counter = 3;
Timer.periodic(const Duration(seconds: 2), (timer) {
print(timer.tick);
counter--;
if (counter == 0) {
print('Cancel timer');
timer.cancel();
}
});
// Outputs:
// 1
// 2
// 3
// "Cancel timer"
实现
factory Timer.periodic(Duration duration, void callback(Timer timer)) {
if (Zone.current == Zone.root) {
// No need to bind the callback. We know that the root's timer will
// be invoked in the root zone.
return Zone.current.createPeriodicTimer(duration, callback);
}
var boundCallback = Zone.current.bindUnaryCallbackGuarded<Timer>(callback);
return Zone.current.createPeriodicTimer(duration, boundCallback);
}