1.首先肯定是容器一啟動就要啟動定時器,所以我們可以選擇把定時器寫在一個監聽器里,容器一啟動所以監聽器也就跟著啟動,然后定時器就可以工作了。
第一步,把自己寫的監聽器加到web.xml中;
第二步,寫一個監聽器,實現ServletContextListener接口;
第三步,寫一個定時器,繼承TimerTask,在復寫的run()方法里寫具體的業務邏輯。
第四步,在自己的監聽器里復寫的
public void contextInitialized(ServletContextEvent arg0){
}
這個方法里調用定時器的schedule方法。
具體代碼如下:
web.xml添加:
1
2
3
4
|
<!-- 用于補償認證信息異常的數據,用來啟動定時器,20170505 --> < listener > < listener-class >com.dcits.app.servlet.MyTimerTaskListener</ listener-class > </ listener > |
MyTimerTaskListener.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
package com.dcits.app.servlet; import java.util.Calendar; import java.util.Timer; import javax.servlet.ServletContextEvent; import javax.servlet.ServletContextListener; /** * @author Weiyongle * @time 2017-5-5 下午2:05:32 */ public class MyTimerTaskListener implements ServletContextListener { @Override public void contextDestroyed(ServletContextEvent arg0) { timer.cancel(); } @Override public void contextInitialized(ServletContextEvent arg0) { System.out.println( "-----開始啟動定時器------" ); Calendar twentyOne = Calendar.getInstance(); twentyOne.set(Calendar.HOUR_OF_DAY, 23 ); twentyOne.set(Calendar.MINUTE, 0 ); twentyOne.set(Calendar.SECOND, 0 ); timer = new Timer( true ); //第一次是晚上23點執行,間隔24小時執行一次 timer.schedule( new MyTimerTask(), twentyOne.getTime(), 1000 * 60 * 60 * 24 ); //*System.out.println("-----開始啟動定時器------"); Calendar twentyOne = Calendar.getInstance(); twentyOne.set(Calendar.HOUR_OF_DAY, 14 ); twentyOne.set(Calendar.MINUTE, 47 ); twentyOne.set(Calendar.SECOND, 0 ); timer = new Timer( true ); timer.schedule( new MyTimerTask(), twentyOne.getTime(), 1000 * 10 );*/ } } |
MyTimerTask.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
package com.dcits.app.servlet; import java.io.IOException; import java.util.HashMap; import java.util.Map; import java.util.TimerTask; import org.codehaus.jackson.JsonGenerationException; import org.codehaus.jackson.map.JsonMappingException; /** * 定時器,用于補償認證的時候沒有獲取到正常返回的那些數據 * @author Weiyongle * @time 2017-5-5 下午2:20:12 */ public class MyTimerTask extends TimerTask{ private static StringBuffer url = new StringBuffer(); @Override public void run() { //生產環境 // url.append("https://我是具體的ip地址/nmsypt/servlet/webServlet");//生產環境 url.append( "http://localhost:8080/adp/servlet/webServlet" ); //本地環境 Map<String,Object> reqMap = new HashMap<String,Object>(); //這里的map從數據庫里獲取對應的數據不寫死就行了,先獲取map,在寫個for循環進行循環就行了 reqMap.put( "QYMC" , "丹同學的公司" ); reqMap.put( "NSRSBH" , "158028307441234" ); reqMap.put( "SJHM_FR" , "15802830744" ); reqMap.put( "YZM" , "123456" ); reqMap.put( "CWFZR" , "" ); // reqMap.put( "ZJLX_DM_CW" , "" ); // reqMap.put( "ZJHM_CW" , "" ); // reqMap.put( "ZGRS" , "1234" ); reqMap.put( "SQYY" , "" ); // reqMap.put( "JRCPBM" , "00002" ); reqMap.put( "XYDM" , "1" ); reqMap.put( "XZQHDM" , "" ); reqMap.put( "QYBM" , "QY17900000647001" ); try { CompensateData.CompensateDatas(url.toString(), reqMap); System.out.println( "-----成功補償了一條認證信息------" ); } catch (JsonGenerationException e) { e.printStackTrace(); } catch (JsonMappingException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } } |
另外,有關于定時器還有事情要介紹,又是一個示例,哈哈,比較有意思的。
運行后,我們發現三秒后控制臺打印出了相當的文字,但是任務雖然執行完了,進程卻沒有銷毀,還是呈紅色狀態,這是什么原因呢?
創建了一個Timer就相當于啟動了一個新線程,這個新線程并不是守護線程,所以會一直運行.
在Time類和TimerTask類中都有一個cancel()方法.
TimerTask類中的作用是:將自身從任務隊列中清除,(一個Timer對象可以執行多個Timertask任務)
Timer類中的作用是:將任務隊列中的全部任務清空.
下面寫一個實例,定時刪除指定磁盤某個目錄下的所有文件:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
package com.wang.reflect; import java.io.File; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.Timer; import java.util.TimerTask; class MyTask extends TimerTask{ /** * 定時刪除指定位置的文件,(這里以刪除f盤下aa文件夾的所有文件為例) */ @Override public void run() { File file= new File( "f://aa" ); deleteFolder(file); } public void deleteFolder(File file){ File[] files=file.listFiles(); for (File f:files){ if (f.isDirectory()){ //使用遞歸 deleteFolder(f); } else { f.delete(); } } file.delete(); } } public class TimerDemo { public static void main(String[] args) throws ParseException { //創建定時器對象 Timer t= new Timer(); String time= "2016-04-04 11:26:40" ; Date d= new SimpleDateFormat( "yyyy-MM-dd HH:mm:ss" ).parse(time); t.schedule( new MyTask(), d); } } |
注意,如果在上面測試代碼中,我給出的Date類型的時間,早于當前的時間.則會立即執行task任務.
總結
以上就是本文關于java定時器timer的使用方法代碼示例全部內容,希望對大家有所幫助。有什么問題請留言指出,感謝大家。
原文鏈接:http://www.cnblogs.com/Sunnor/p/6813098.html