Java定時任務(wù)schedule和scheduleAtFixedRate的異同
一、使用
相同點
- 任務(wù)執(zhí)行未超時,則下次執(zhí)行時間 = 上次執(zhí)行開始時間 + period
- 任務(wù)執(zhí)行超時,則下次執(zhí)行時間 = 上次執(zhí)行結(jié)束時間
不同點
- schedule在錯過以后會按照自己的節(jié)奏繼續(xù)走,可能會導(dǎo)致丟失任務(wù),但時間間隔穩(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) {
? ? ? ? // 任務(wù)此時已經(jīng)啟動
? ? ? ? Timer t = new Timer();
? ? ? ? TimerTask task = new CustomTimerTask("test");
? ? ? ? // 添加任務(wù)
? ? ? ? /*
? ? ? ? ?* 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的位置,它的開始時間是上一個線程的結(jié)束時間,它有在努力追趕,但后續(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的位置,它的開始時間是上一個線程的結(jié)束時間,并且在其后還有一個線程5,說明scheduleAtFixedRate還是在很努力地加油想把之前落下的線程補回來的。
到此這篇關(guān)于Java定時任務(wù)schedule和scheduleAtFixedRate的異同的文章就介紹到這了,更多相關(guān)Java schedule scheduleAtFixedRate內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android應(yīng)用開發(fā)之將SQLite和APK一起打包的方法
這篇文章主要介紹了Android應(yīng)用開發(fā)之將SQLite和APK一起打包的方法,文章時間較早,盡管現(xiàn)在開發(fā)環(huán)境已大都遷移至Android Studio上,但打包原理依然相同,需要的朋友可以參考下2015-08-08
在Java的Struts中判斷是否調(diào)用AJAX及用攔截器對其優(yōu)化
這篇文章主要介紹了在Java的Struts中判斷是否調(diào)用AJAX及用攔截器對其優(yōu)化的方法,Struts框架是Java的SSH三大web開發(fā)框架之一,需要的朋友可以參考下2016-01-01
java中javamail發(fā)送帶附件的郵件實現(xiàn)方法
這篇文章主要介紹了java中javamail發(fā)送帶附件的郵件實現(xiàn)方法,較為詳細的分析了JavaMail發(fā)送郵件的用法,是非常實用的技巧,需要的朋友可以參考下2015-01-01
Struts2通過自定義標簽實現(xiàn)權(quán)限控制的方法
這篇文章主要介紹了Struts2通過自定義標簽實現(xiàn)權(quán)限控制的方法,介紹了定義Struts2的自定義標簽的三個步驟以及詳細解釋,需要的朋友可以參考下。2017-09-09
Spring boot中filter類不能注入@Autowired變量問題
這篇文章主要介紹了Spring boot中filter類不能注入@Autowired變量問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09
Java之Rsync并發(fā)遷移數(shù)據(jù)并校驗詳解
這篇文章主要介紹了Java之Rsync并發(fā)遷移數(shù)據(jù)并校驗詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-08-08

