Java定時(shí)任務(wù)schedule和scheduleAtFixedRate的異同
一、使用
相同點(diǎn)
- 任務(wù)執(zhí)行未超時(shí),則下次執(zhí)行時(shí)間 = 上次執(zhí)行開始時(shí)間 + period
- 任務(wù)執(zhí)行超時(shí),則下次執(zhí)行時(shí)間 = 上次執(zhí)行結(jié)束時(shí)間
不同點(diǎn)
- schedule在錯(cuò)過以后會(huì)按照自己的節(jié)奏繼續(xù)走,可能會(huì)導(dǎo)致丟失任務(wù),但時(shí)間間隔穩(wěn)定。
- scheduleAtFixedRate在錯(cuò)過后,會(huì)努力追趕進(jìn)度,以確保保持執(zhí)行頻率的穩(wěn)定。
代碼示例
我們進(jìn)行一個(gè)簡(jiǎn)單的測(cè)試,在下面的代碼中,每3秒就會(huì)有一個(gè)間隔5秒的線程休眠(模擬超時(shí)),對(duì)比一下二者輸出數(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ù)此時(shí)已經(jīng)啟動(dòng) ? ? ? ? Timer t = new Timer(); ? ? ? ? TimerTask task = new CustomTimerTask("test"); ? ? ? ? // 添加任務(wù) ? ? ? ? /* ? ? ? ? ?* schedule 保持間隔時(shí)間的穩(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ù)對(duì)比
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的位置,它的開始時(shí)間是上一個(gè)線程的結(jié)束時(shí)間,它有在努力追趕,但后續(xù)并沒有把之前落下的線程補(bǔ)回來。
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的位置,它的開始時(shí)間是上一個(gè)線程的結(jié)束時(shí)間,并且在其后還有一個(gè)線程5,說明scheduleAtFixedRate還是在很努力地加油想把之前落下的線程補(bǔ)回來的。
到此這篇關(guān)于Java定時(shí)任務(wù)schedule和scheduleAtFixedRate的異同的文章就介紹到這了,更多相關(guān)Java schedule scheduleAtFixedRate內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java實(shí)現(xiàn)的小時(shí)鐘示例分享
這篇文章主要介紹了java實(shí)現(xiàn)的小時(shí)鐘示例,需要的朋友可以參考下2014-02-02Java實(shí)現(xiàn)BASE64編碼和解碼的方法
本篇文章主要介紹了Java實(shí)現(xiàn)BASE64編碼和解碼的方法,BASE64編碼通常用于轉(zhuǎn)換二進(jìn)制數(shù)據(jù)為文本數(shù)據(jù),有需要的可以了解一下。2016-11-11javafx tableview鼠標(biāo)觸發(fā)更新屬性詳解
這篇文章主要為大家詳細(xì)介紹了javafx tableview鼠標(biāo)觸發(fā)更新屬性的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08Java利用iTextPDF庫實(shí)現(xiàn)制作PDF表格模板并填充數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了如何通過Java的iTextPDF庫制作一個(gè)PDF表格模板并填充數(shù)據(jù),文中的示例代碼講解詳細(xì),感興趣的小伙伴快跟隨小編一起學(xué)習(xí)一下吧2023-12-12Java中的LinkedHashMap及LRU緩存機(jī)制詳解
這篇文章主要介紹了Java中的LinkedHashMap及LRU緩存機(jī)制詳解,LinkedHashMap繼承自HashMap,它的多種操作都是建立在HashMap操作的基礎(chǔ)上的,同HashMap不同的是,LinkedHashMap維護(hù)了一個(gè)Entry的雙向鏈表,保證了插入的Entry中的順序,需要的朋友可以參考下2023-09-09解析spring-boot-starter-parent簡(jiǎn)介
本文通過代碼的形式給大家介紹了spring-boot-starter-parent的基礎(chǔ)知識(shí),需要的朋友可以參考下2018-09-09