本文主要討論java.util.Timer的schedule(timerTask,delay,period)和scheduleAtFixedRate(timerTask,delay,period)的區別。
這兩個函數不管是哪一個,TImer都是單線程的,任務始終在這個單線程里面執行。
下面討論四種情況:
[(任務3s,間隔2s)+(任務2s,間隔3s)]×[schedule+scheduleAtFixedRate]
schedule,任務3s,間隔2s
new Timer().schedule(new TimerTask() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + " " + scheduledExecutionTime() / 1000 + " " + System.currentTimeMillis() / 1000);
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}, 0, 2000);
輸出為
Timer-0 1519651551 1519651551
Timer-0 1519651554 1519651554
Timer-0 1519651557 1519651557
schedule,任務2s,間隔3s
把上面代碼中的Thread.sleep()改為2s,把interval改為3s
Timer-0 1519651602 1519651602
Timer-0 1519651605 1519651605
Timer-0 1519651608 1519651608
scheduleAtFixedRate,任務3s,間隔2s
new Timer().scheduleAtFixedRate(new TimerTask() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + " " + scheduledExecutionTime() / 1000 + " " + System.currentTimeMillis() / 1000);
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}, 0, 2000);
輸出為
Timer-0 1519651707 1519651707
Timer-0 1519651709 1519651710
Timer-0 1519651711 1519651713
Timer-0 1519651713 1519651716
scheduleAtFixedRate,任務2s,間隔3s
Timer-0 1519651750 1519651750
Timer-0 1519651753 1519651753
Timer-0 1519651756 1519651756
總結
下面定義四個名稱:
timer.scheduledExecutionTime()為理論時間間隔
System.currentMilliSeconds()為實際時間間隔
schedule(task,delay,interval)和scheduleAtFixedRate(task,delay,interval)中的interval參數為設定時間間隔
任務時間:執行任務所花費的時間
schedule()運行時,理論時間間隔總是等於實際時間間隔,此時間間隔為max(任務時間,設定時間間隔)
scheduleAtFixedRate()運行時,理論時間間隔總是等於設定的時間間隔,實際時間間隔總是等於max(任務時間,間隔時間)。