Java定時任務schedule和scheduleAtFixedRate的異同
一、使用
相同點
- 任務執(zhí)行未超時,則下次執(zhí)行時間 = 上次執(zhí)行開始時間 + period
- 任務執(zhí)行超時,則下次執(zhí)行時間 = 上次執(zhí)行結束時間
不同點
- schedule在錯過以后會按照自己的節(jié)奏繼續(xù)走,可能會導致丟失任務,但時間間隔穩(wěn)定。
- scheduleAtFixedRate在錯過后,會努力追趕進度,以確保保持執(zhí)行頻率的穩(wěn)定。
代碼示例
我們進行一個簡單的測試,在下面的代碼中,每3秒就會有一個間隔5秒的線程休眠(模擬超時),對比一下二者輸出數(shù)據(jù)的區(qū)別。
package com; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.Timer; import java.util.TimerTask; public class TimerTest { ? ? public static void main(String[] args) { ? ? ? ? // 任務此時已經(jīng)啟動 ? ? ? ? Timer t = new Timer(); ? ? ? ? TimerTask task = new CustomTimerTask("test"); ? ? ? ? // 添加任務 ? ? ? ? /* ? ? ? ? ?* schedule 保持間隔時間的穩(wěn)定 ? ? ? ? ?* scheduleAtFixedRate 保持執(zhí)行頻率的穩(wěn)定 ? ? ? ? ?*/ ? ? ? ? t.schedule(task, new Date(), 2000); // ? ? ? ?t.scheduleAtFixedRate(task, new Date(), 2000); ? ? } } class CustomTimerTask extends TimerTask { ? ? private String name; ? ? int count = 1; ? ? private final SimpleDateFormat dateFormatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); ? ? public CustomTimerTask(String name) { ? ? ? ? this.name = name; ? ? } ? ? @Override ? ? public void run() { ? ? ? ? try { ? ? ? ? ? ? System.out.println("線程 : " + count); ? ? ? ? ? ? System.out.println("startTime = " + dateFormatter.format(new Date())); ? ? ? ? ? ? if (count % 3 == 0) { ? ? ? ? ? ? ? ? Thread.sleep(5000); ? ? ? ? ? ? } ? ? ? ? ? ? count++; ? ? ? ? ? ? System.out.println("endTime = " + dateFormatter.format(new Date()) + "\r\n"); ? ? ? ? } catch (InterruptedException e) { ? ? ? ? ? ? e.printStackTrace(); ? ? ? ? } ? ? } }
輸出數(shù)據(jù)對比
schedule
線程 : 1
startTime = 2023-02-25 10:20:28
endTime = 2023-02-25 10:20:28線程 : 2
startTime = 2023-02-25 10:20:30
endTime = 2023-02-25 10:20:30線程 : 3
startTime = 2023-02-25 10:20:32
endTime = 2023-02-25 10:20:37線程 : 4
startTime = 2023-02-25 10:20:37
endTime = 2023-02-25 10:20:37線程 : 5
startTime = 2023-02-25 10:20:39
endTime = 2023-02-25 10:20:39線程 : 6
startTime = 2023-02-25 10:20:41
endTime = 2023-02-25 10:20:46線程 : 7
startTime = 2023-02-25 10:20:46
endTime = 2023-02-25 10:20:46線程 : 8
startTime = 2023-02-25 10:20:48
endTime = 2023-02-25 10:20:48線程 : 9
startTime = 2023-02-25 10:20:50
endTime = 2023-02-25 10:20:55線程 : 10
startTime = 2023-02-25 10:20:55
endTime = 2023-02-25 10:20:55線程 : 11
startTime = 2023-02-25 10:20:57
endTime = 2023-02-25 10:20:57
可以看到,schedule在線程4的位置,它的開始時間是上一個線程的結束時間,它有在努力追趕,但后續(xù)并沒有把之前落下的線程補回來。
scheduleAtFixedRate
線程 : 1
startTime = 2023-02-25 10:18:59
endTime = 2023-02-25 10:18:59線程 : 2
startTime = 2023-02-25 10:19:01
endTime = 2023-02-25 10:19:01線程 : 3
startTime = 2023-02-25 10:19:03
endTime = 2023-02-25 10:19:08線程 : 4
startTime = 2023-02-25 10:19:08
endTime = 2023-02-25 10:19:08線程 : 5
startTime = 2023-02-25 10:19:08
endTime = 2023-02-25 10:19:08線程 : 6
startTime = 2023-02-25 10:19:09
endTime = 2023-02-25 10:19:14線程 : 7
startTime = 2023-02-25 10:19:14
endTime = 2023-02-25 10:19:14線程 : 8
startTime = 2023-02-25 10:19:14
endTime = 2023-02-25 10:19:14線程 : 9
startTime = 2023-02-25 10:19:15
endTime = 2023-02-25 10:19:20線程 : 10
startTime = 2023-02-25 10:19:20
endTime = 2023-02-25 10:19:20線程 : 11
startTime = 2023-02-25 10:19:20
endTime = 2023-02-25 10:19:20
同樣是線程4的位置,它的開始時間是上一個線程的結束時間,并且在其后還有一個線程5,說明scheduleAtFixedRate還是在很努力地加油想把之前落下的線程補回來的。
到此這篇關于Java定時任務schedule和scheduleAtFixedRate的異同的文章就介紹到這了,更多相關Java schedule scheduleAtFixedRate內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
javafx tableview鼠標觸發(fā)更新屬性詳解
這篇文章主要為大家詳細介紹了javafx tableview鼠標觸發(fā)更新屬性的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08Java利用iTextPDF庫實現(xiàn)制作PDF表格模板并填充數(shù)據(jù)
這篇文章主要為大家詳細介紹了如何通過Java的iTextPDF庫制作一個PDF表格模板并填充數(shù)據(jù),文中的示例代碼講解詳細,感興趣的小伙伴快跟隨小編一起學習一下吧2023-12-12解析spring-boot-starter-parent簡介
本文通過代碼的形式給大家介紹了spring-boot-starter-parent的基礎知識,需要的朋友可以參考下2018-09-09