本文中Java定时任务一共有三种,分别是利用Thread类中sleep()方法,Timer与TimerTask类以及ScheduledExecutorService接口来实现延时以及定时任务。

一.<!--[endif]-->类

这是最简单的一种方法,通过创建一个Thread类,让其一直在while循环中执行,并通过sleep方法延时一段时间便可以达到定时任务的目的。

简单代码如下:



Java代码 

1. package
2.   
3. public class Maintest extends
4.       
5. private final int interval = 1000;  
6.       
7. public static void
8. new
9.         mt.start();  
10.           
11.     }  
12.       
13. public void
14. while(true){  
15. try
16.                 sleep(interval);  
17. catch
18.                 e.printStackTrace();  
19.             }  
20. "定时任务已执行!!");  
21.         }  
22.     }  
23.       
24. }



而这种方法的缺点也是显而易见的,由于sleep()方法本身的缺陷,导致定时可能会不大精确,同时不方便用户修改启动的delay时间,而且启动与停止任务并不方便控制。

二.Timer类与TimerTask类

该方法通过使用Timer类来启动任务,TimerTask类通过run方法来实现具体的定时任务内容。

这种方法虽然没有之前那种那么简单快速,但明显也多了很多有用的功能,在实现时,Timer类用于调度任务,功能是在指定的时间间隔内反复触发指定窗口的定时器事件,而TimerTask类用于创建一个新线程,执行具体任务。



Java代码 

1. public static void
2. //      Maintest mt = new Maintest();
3. //      mt.start();
4. new
5. public void
6. //具体任务的操作
7. "定时任务");  
8.             }  
9.         };  
10. new
11. long delay = 0;  
12. long period = 1*1000;  
13.         time.scheduleAtFixedRate(tt, delay, period);  
14. }



 

上面即是使用Timer类与TimerTask类来实现Java定时任务,这种方法的比直接在一个线程中使用sleep()方法无疑功能多了很多,例如,可以控制启动与任务的停止,其次还可以指定任务延时启动。但是由于Timer类使用过的是单线程,在处理需要多个线程同时使用者,有着明显的不足之处,因此,我们可以使用第三种方法ScheduledExecutorService接口。

三.ScheduledExecutorService接口

根据我查的资料,ScheduledExecutorService接口是从Java SE 5的java.util.concurrent里,做为并发工具类被引进的,这是最理想的定时任务实现方式。而相较于之前的几种方法,这种方法使用的不是单线程的方法,而是通过使用线程池来执行任务的,那么线程池是什么呢?线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。那么使用线程池的优点有哪些?

1、可以优化资源的使用效率,提高其性能;

2、可以完成需要大量线程的任务;

3、对性能要求苛刻的应用;

4、接受突发性的大量请求,但不至于使服务器因此产生大量线程的应用。

 

示例:



Java代码 

1. Runnable run = new
2. public void
3. "每隔一秒钟输出一次!!!");  
4.             }  
5.               
6.         };  
7. //安排延时任务
8.         ScheduledExecutorService service = Executors.newSingleThreadScheduledExecutor();  
9. 0, 1, TimeUnit.SECONDS);