本文實例主要進行java Timer(定時調用、固定時間執行)測試,具體實現代碼如下。
當任務執行時間小於重複執行的間隔時間
代碼:
public class TimerTest2 { public static void main(String[] args) throws InterruptedException { Timer timer = new Timer(); timer.schedule(new MyTask(0), 1000, 10000); //timer.schedule(new MyTask(1), 1000, 10000); } static class MyTask extends TimerTask { private final int i; public MyTask(int i) { this.i = i; } @Override public void run() { System.out.println(i + "dddd" + DateTimeUtil.getDateTimeString("yyyy-MM-dd HH:mm:ss.SSS")); try { if (i == 0) { Thread.sleep(8000L); } else { Thread.sleep(13000L); } } catch (Exception e) { e.printStackTrace(); } } }}結果:
0dddd2018-01-11 15:34:57.826
0dddd2018-01-11 15:35:07.824
0dddd2018-01-11 15:35:17.824
0dddd2018-01-11 15:35:27.824
0dddd2018-01-11 15:35:37.824
0dddd2018-01-11 15:35:47.824
0dddd2018-01-11 15:35:57.824
0dddd2018-01-11 15:36:07.824
0dddd2018-01-11 15:36:17.824
0dddd2018-01-11 15:36:27.824
0dddd2018-01-11 15:36:37.824
0dddd2018-01-11 15:36:47.824
0dddd2018-01-11 15:36:57.824
0dddd2018-01-11 15:37:07.824
0dddd2018-01-11 15:37:17.824
0dddd2018-01-11 15:37:27.824
0dddd2018-01-11 15:37:37.824
當任務執行時間大於重複執行的間隔時間
代碼:
public class TimerTest2 { public static void main(String[] args) throws InterruptedException { Timer timer = new Timer(); //timer.schedule(new MyTask(0), 1000, 10000); timer.schedule(new MyTask(1), 1000, 10000); } static class MyTask extends TimerTask { private final int i; public MyTask(int i) { this.i = i; } @Override public void run() { System.out.println(i + "dddd" + DateTimeUtil.getDateTimeString("yyyy-MM-dd HH:mm:ss.SSS")); try { if (i == 0) { Thread.sleep(8000L); } else { Thread.sleep(13000L); } } catch (Exception e) { e.printStackTrace(); } } }}結果:
1dddd2018-01-11 16:03:07.575
1dddd2018-01-11 16:03:20.601
1dddd2018-01-11 16:03:33.602
1dddd2018-01-11 16:03:46.603
1dddd2018-01-11 16:03:59.604
1dddd2018-01-11 16:04:12.606
1dddd2018-01-11 16:04:25.607
1dddd2018-01-11 16:04:38.608
以上就是本文關於java Timer測試定時調用及固定時間執行代碼示例的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!