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(任務時間,間隔時間)。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM