java atrate_Java中timer的schedule()和schedualAtFixedRate()函數的區別

本文主要討論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(任務時間,間隔時間)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值