Java線程Timer定時器用法詳細總結(jié)
定時/計劃功能主要使用的就是Timer對象,它在內(nèi)部還是使用多線程的方式進行處理,所以它和線程技術(shù)還是有非常大的關(guān)聯(lián)。
Timer類主要作用就是設(shè)置計劃任務(wù),但封裝任務(wù)的類卻是TimerTask類。TimerTask類是一個抽象類。
執(zhí)行任務(wù)的時間晚于當前時間-----在未來執(zhí)行的效果
import java.util.Date; import java.util.TimerTask; public class MyTask extends TimerTask{ @Override public void run() { System.out.println("任務(wù)執(zhí)行了, 時間為:" + new Date()); } } public class Test1 { public static void main(String[] args){ System.out.println("當前時間為: " + new Date()); Calendar calendarRef = Calendar.getInstance(); calendarRef.add(Calendar.SECOND, 10); Date runDate = calendarRef.getTime(); MyTask task = new MyTask(); // 查看Timer構(gòu)造方法,創(chuàng)建一個Timer就是啟動一個新的線程 Timer timer = new Timer(); timer.schedule(task, runDate); // 定時器在某個時間(runDate)執(zhí)行某個任務(wù)(task) } }
Timer中允許有多個TimerTask任務(wù)及延時的測試
TimerTask是以隊列的方式一個一個被順序性地執(zhí)行,所以執(zhí)行時間有可能和預(yù)期的時間不一致,因為前面的任務(wù)有可能消耗的時間較長,則后面的任務(wù)運行的時間也被延后。
import java.util.Date; import java.util.TimerTask; public class MyTaskA extends TimerTask{ @Override public void run() { try { System.out.println("A begin timer, 時間為:" + new Date()); Thread.sleep(20000); System.out.println("A end timer, 時間為:" + new Date()); } catch (InterruptedException e) { e.printStackTrace(); } } } import java.util.Date; import java.util.TimerTask; public class MyTaskB extends TimerTask{ @Override public void run() { System.out.println("B begin timer, 時間為:" + new Date()); System.out.println("B end timer, 時間為:" + new Date()); } } import java.util.Calendar; import java.util.Date; import java.util.Timer; public class Test1 { public static void main(String[] args){ System.out.println("當前時間為: " + new Date()); Calendar calendarRef1 = Calendar.getInstance(); Date runDate1 = calendarRef1.getTime(); System.out.println("A計劃時間為: " + runDate1); Calendar calendarRef2 = Calendar.getInstance(); calendarRef2.add(Calendar.SECOND, 10); Date runDate2 = calendarRef2.getTime(); System.out.println("B計劃時間為: " + runDate2); MyTaskA task1 = new MyTaskA(); MyTaskB task2 = new MyTaskB(); Timer timer = new Timer(); timer.schedule(task1, runDate1); // 定時器在某個時間(runDate)執(zhí)行某個任務(wù)(task) timer.schedule(task2, runDate2); } }
schedule(TimerTask task, Date firstTime, long period)
該方法的作用是在指定的日期之后按指定的間隔周期,無限循環(huán)地執(zhí)行某一任務(wù)。
import java.util.Date; import java.util.TimerTask; public class MyTask extends TimerTask{ @Override public void run() { System.out.println("任務(wù)開始: "+new Date()); System.out.println("mytask..."); System.out.println("任務(wù)結(jié)束: "+new Date()); } } import java.util.Calendar; import java.util.Date; import java.util.Timer; public class Run { public static void main(String[] args){ System.out.println("當前時間為:"+new Date()); Calendar c = Calendar.getInstance(); c.add(Calendar.SECOND, 10); Date runDate1 = c.getTime(); System.out.println("計劃時間為:"+runDate1); MyTask myTask = new MyTask(); Timer timer = new Timer(); timer.schedule(myTask, runDate1, 10000); } }
TimerTask類的cancel()方法
TimerTask類中的cancel()方法的作用是將自身從任務(wù)隊列中進行清除.
import java.util.Date; import java.util.TimerTask; public class MyTaskA extends TimerTask{ @Override public void run() { System.out.println("A run timer="+new Date()); this.cancel(); System.out.println("A任務(wù)自己移除自己"); } } import java.util.Date; import java.util.TimerTask; public class MyTaskB extends TimerTask{ @Override public void run() { System.out.println("B run timer="+new Date()); } } import java.util.Calendar; import java.util.Date; import java.util.Timer; public class Run { public static void main(String[] args){ System.out.println("當前時間為:"+new Date()); Calendar c = Calendar.getInstance(); Date runDate1 = c.getTime(); System.out.println("計劃時間為:"+runDate1); MyTaskA myTaskA = new MyTaskA(); MyTaskB myTaskB = new MyTaskB(); Timer timer = new Timer(); timer.schedule(myTaskA, runDate1, 4000); timer.schedule(myTaskB, runDate1, 4000); } }
Timer的cancel()方法
和TimerTask類中的cancel()方法清除自身不同,Timer類中的cancel()方法作用是將任務(wù)隊列中全部的任務(wù)進行清空。
import java.util.Date; import java.util.TimerTask; public class MyTaskA extends TimerTask{ @Override public void run() { System.out.println("A run timer="+new Date()); this.cancel(); System.out.println("A任務(wù)自己移除自己"); } } import java.util.Date; import java.util.TimerTask; public class MyTaskB extends TimerTask{ @Override public void run() { System.out.println("B run timer="+new Date()); } } import java.util.Calendar; import java.util.Date; import java.util.Timer; public class Run { public static void main(String[] args){ System.out.println("當前時間為:"+new Date()); Calendar c = Calendar.getInstance(); Date runDate1 = c.getTime(); System.out.println("計劃時間為:"+runDate1); MyTaskA myTaskA = new MyTaskA(); MyTaskB myTaskB = new MyTaskB(); Timer timer = new Timer(); timer.schedule(myTaskA, runDate1, 4000); timer.schedule(myTaskB, runDate1, 4000); } }
schedule(TimerTask task, long delay)
該方法的作用是以執(zhí)行schedule(TimerTask task, long delay)方法當前的時間為參考時間,在此時間基礎(chǔ)上延遲指定的毫秒數(shù)后執(zhí)行一次TimerTask任務(wù)。
import java.util.Date; import java.util.TimerTask; public class MyTask extends TimerTask{ @Override public void run() { System.out.println("A run timer="+new Date()); } } import java.util.Calendar; import java.util.Date; import java.util.Timer; public class Run { public static void main(String[] args) throws InterruptedException{ System.out.println("當前時間為:"+new Date()); Calendar c = Calendar.getInstance(); Date runDate1 = c.getTime(); System.out.println("計劃時間為:"+runDate1); MyTask myTask = new MyTask(); Timer timer = new Timer(); timer.schedule(myTask, 7000); // 計劃任務(wù)延遲7秒后執(zhí)行 Thread.sleep(10000); timer.cancel(); } }
以上就是Java線程之Timer定時器的詳細內(nèi)容,希望腳本之家整理的內(nèi)容能夠幫助到大家。
相關(guān)文章
java中Servlet監(jiān)聽器的工作原理及示例詳解
這篇文章主要介紹了java中Servlet監(jiān)聽器的工作原理及示例詳解。Servlet監(jiān)聽器用于監(jiān)聽一些重要事件的發(fā)生,監(jiān)聽器對象可以在事情發(fā)生前、發(fā)生后可以做一些必要的處理。感興趣的可以來了解一下2020-07-07關(guān)于eclipse中運行tomcat提示端口被占用的4種解決
這篇文章主要介紹了關(guān)于eclipse中運行tomcat提示端口被占用的4種解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01Spring Boot中slf4j日志依賴關(guān)系示例詳解
在項目開發(fā)中,記錄日志是必做的一件事情。而當我們使用Springboot框架時,記錄日志就變得極其簡單了。下面這篇文章主要給大家介紹了關(guān)于Spring Boot中slf4j日志依賴關(guān)系的相關(guān)資料,需要的朋友可以參考下2018-11-11關(guān)于spring依賴注入的方式以及優(yōu)缺點
這篇文章主要介紹了關(guān)于spring依賴注入的方式以及優(yōu)缺點,依賴注入,是IOC的一個方面,是個通常的概念,它有多種解釋,這概念是說你不用創(chuàng)建對象,而只需要描述它如何被創(chuàng)建,需要的朋友可以參考下2023-07-07spring?aop?pointcut?添加多個execution方式
這篇文章主要介紹了spring?aop?pointcut?添加多個execution方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11