更新時(shí)間:2020-05-14 15:41:42 來源:動力節(jié)點(diǎn) 瀏覽2890次
第一步:編寫測試類,該類extendsTimerTask,重新run()方法,run方法里面就是你要執(zhí)行的邏輯代碼,示例如下:
[java]viewplaincopyprint?
importjava.text.SimpleDateFormat;
importjava.util.Date;
importjava.util.TimerTask;
publicclassMyTest1extendsTimerTask{
privateSimpleDateFormatsf=newSimpleDateFormat("yyyy-MM-ddhh:mm:ss");
@Override
publicvoidrun(){
System.out.println("現(xiàn)在時(shí)間是:"+sf.format(newDate()));
}
}
第二步:編寫一個(gè)類,該類實(shí)現(xiàn)ServletContextListener接口
[java]viewplaincopyprint?
importjavax.servlet.ServletContextEvent;
importjavax.servlet.ServletContextListener;
publicclassTimerTaskManagerimplementsServletContextListener{
privateTimertimer;
@Override
publicvoidcontextInitialized(ServletContextEventsce){
System.out.println("程序定時(shí)執(zhí)行任務(wù).....................................");
MyTest1t=newMyTest1();
timer=newTimer("開始執(zhí)行任務(wù)",true);
/*執(zhí)行MyTest1中的run方法,t代表TimerTask的子類,0代表延遲0毫秒執(zhí)行run方*法,1000表示每隔一秒執(zhí)行一次run方法,后面兩個(gè)參數(shù)可根據(jù)自己的需求而定義
*/
timer.schedule(t,0,1000);
}
@Override
publicvoidcontextDestroyed(ServletContextEventsce){
System.out.println("程序定時(shí)執(zhí)行任務(wù)結(jié)束.....................................");
timer.cancel();
}
}
第三步:在web.xml中添加如下代碼里面填寫TimerTaskManager的路徑,程序在web容器啟動后會初始化加載TimerTaskManager的contextInitialized方法。
監(jiān)聽器添加方式:
加listener標(biāo)簽,listener里面加listener-class標(biāo)簽,listener-class標(biāo)簽里面內(nèi)容為TimerTaskManager的路徑,如:com.TimerTaskManager.
舉例:
[html]viewplaincopyprint?
<listener>
<listener-class>weiming.lmapp.timer.SysContextListener</listener-class>
</listener>
相關(guān)注意點(diǎn)分析:
1.任務(wù)調(diào)度要優(yōu)先考慮實(shí)時(shí)保證
由于Java的天性,并且在開發(fā)JDK的過程中要考慮到不同平臺,而不同平臺的線程調(diào)度機(jī)制是不同的,因此各種平臺下JVM的線程調(diào)度機(jī)制也是不一致的。從而Timer不能保證任務(wù)在所指定的時(shí)間內(nèi)執(zhí)行。另外由于TimerTask是實(shí)現(xiàn)Runnable接口的,在TimerTask被放進(jìn)線程隊(duì)列睡眠一段時(shí)間(wait)之后,當(dāng)?shù)搅酥付ǖ脑搯酒鹪揟imerTask時(shí),由于執(zhí)行的確切時(shí)機(jī)取決于JVM的調(diào)度策略和當(dāng)前還有多少線程在等待CPU處理。因此就不能保證任務(wù)在所指定的時(shí)間內(nèi)執(zhí)行。通常在如下兩種情況下導(dǎo)致任務(wù)延遲執(zhí)行:
(1)有大量線程在等待執(zhí)行
(2)GC機(jī)制的影響導(dǎo)致延遲
這也是為什么在TimerAPI中存在兩組調(diào)度方法的原因。即:
(1)schedule()
用固定延遲調(diào)度。使用本方法時(shí),在任務(wù)執(zhí)行中的每一個(gè)延遲會傳播到后續(xù)的任務(wù)的執(zhí)行。
(2)scheduleAsFixedRate()
用固定比率調(diào)度。使用本方法時(shí),所有后續(xù)執(zhí)行根據(jù)初始執(zhí)行的時(shí)間進(jìn)行調(diào)度,從而希望減小延遲。
具體使用哪一個(gè)方法取決于哪些參數(shù)對你的程序或系統(tǒng)更重要。
2.每個(gè)Timer對象要在后臺啟動一個(gè)線程。這種性質(zhì)在一些托管的環(huán)境下不推薦使用,比如在應(yīng)用服務(wù)器中。因?yàn)檫@些線程不在容器的控制范圍之內(nèi)了。
以上就是動力節(jié)點(diǎn)java培訓(xùn)機(jī)構(gòu)的小編針對“java timer的用法,三步實(shí)現(xiàn)定時(shí)”的內(nèi)容進(jìn)行的回答,希望對大家有所幫助,如有疑問,請?jiān)诰€咨詢,有專業(yè)老師隨時(shí)為你服務(wù)。
相關(guān)閱讀
初級 202925
初級 203221
初級 202629
初級 203743