一、概念
定时计划任务功能在java中主要使用的就是timer对象,它在内部使用多线程的方式进行处理,所以它和多线程技术还是有非常大的关联的。在jdk中timer类主要负责计划任务的功能,也就是在指定的时间开始执行某一个任务,但封装任务的类却是timertask类。
通过继承 timertask 类 并实现 run() 方法来自定义要执行的任务:
1
2
3
4
5
6
7
8
|
public class mytask extends timertask { @override public void run() { dateformat dateformat = timeutil.df.get(); system.out.println( "我的任务运行了" + dateformat.format( new date())); } } |
通过执行timer.schedule(timertask task,date time) 在执行时间运行任务:
1
2
3
4
5
6
7
8
|
public class run { private static timer timer= new timer(); public static void main(string[] args) throws parseexception { timer.schedule( new mytask(), timeutil.df.get().parse( "2017-09-14 09:19:30" )); } } |
备注:时间转换工具类,保证线程安全:
1
2
3
4
5
6
7
8
9
|
public class timeutil { public static final threadlocal<dateformat> df = new threadlocal<dateformat>() { @override protected dateformat initialvalue() { return new simpledateformat( "yyyy-mm-dd hh:mm:ss" ); } }; } |
二、timer类注意事项
1、创建一个 timer 对象就是新启动了一个线程,但是这个新启动的线程,并不是守护线程,它一直在后台运行,通过如下 可以将新启动的 timer 线程设置为守护线程。
1
|
private static timer timer= new timer( true ); |
2、提前:当计划时间早于当前时间,则任务立即被运行。
3、延迟:timertask 是以队列的方式一个一个被顺序运行的,所以执行的时间和你预期的时间可能不一致,因为前面的任务可能消耗的时间较长,则后面的任务运行的时间会被延迟。延迟的任务具体开始的时间,就是依据前面任务的"结束时间"
4、周期性运行:timer.schedule(timertask task,date firsttime,long period) 从 firsttime 开始每隔 period 毫秒执行一次任务:
5、schedule(timertask task,long delay) 当前的时间为参考时间,在此时间基础上延迟制定的毫秒数后执行一次timertask任务。
6、schedule(timertask task,long delay,long period) 当前的时间为参考时间,在此基础上延迟制定的毫秒数,再以某一间隔时间无限次数地执行某一任务。
7、timer的cancel() 和 timertask的cancel() 的区别?
前面提到任务的执行是以对列的方式一个个被顺序执行的,timertask.cancel() 指的是 把当前任务从任务对列里取消。timer.cancel() 值的是把当前任务队列里的所有任务都取消。值得注意的是,timer 的cancel()有时并不一定会停止执行计划任务,而是正常执行。这是因为timer类中的cancel()方法有时并没有争抢到queue锁,所以timertask类中的任务继续正常执行。
三、scheduleatfixedrate(timertask task,date firsttime,long period) 和 schedule(timertask task,date firsttime,long period) 区别
相同点:
1、方法schedule 和方法 scheduleatfixedrate 都会按顺序执行,所以不用考虑非线程安全的情况。
2、方法schedule 和方法 scheduleatfixedrate 如果执行任务的时间没有被延迟,那么下一次任务的执行时间参考的是上一次的任务的"开始"时的时间来计算的。
3、方法schedule 和方法 scheduleatfixedrate 如果执行任务的时间被延迟了,那么下一次任务的执行时间参考的是上一次任务"结束"时的时间来计算。
不同点:
方法schedule 和方法 scheduleatfixedrate 在使用上基本没什么差别,就是 scheduleatfixedrate 具有追赶执行性,什么意思呢?就是如果任务 在周期性运行过程中被打断了,scheduleatfixedrate 会尝试把之前落下的任务补上运行。而schedule就不管了,接着运行接下来的任务就行了,可以参考这篇博客,写的很生动。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.cnblogs.com/jmcui/p/7519759.html