Java中Timer的schedule()方法参数详解
timer.schedule(newMyTask(),longtime1,longtimer2);
今天算是彻底的搞懂了这个曾经让我为之头疼的方法。下面我就重点介绍一下:
- 第一个参数,是TimerTask类,在包:importJava.util.TimerTask.使用者要继承该类,并实现publicvoidrun()方法,因为TimerTask类实现了Runnable接口。
- 第二个参数的意思是,当你调用该方法后,该方法必然会调用TimerTask类TimerTask类中的run()方法,这个参数就是这两者之间的差值,转换成汉语的意思就是说,用户调用schedule()方法后,要等待这么长的时间才可以第一次执行run()方法。
- 第三个参数的意思就是,第一次调用之后,从第二次开始每隔多长的时间调用一次run()方法。
附:
技术人员在实现内部办公系统与外部网站一体化的时候,最重要的步骤就是从OA系统读取数据,并且根据网站模板生成最终的静态页面。这里就需要一个定时任务,循环的执行。
技术人员在写定时任务的时候,想当然的以为Timer.schedule(TimerTasktask,longdelay)就是重复的执行task。程序运行后发现只运行了一次,总觉得是task里的代码有问题,花了很长时间调试代码都没有结果。
仔细研读javaapi,发现:
schedule(TimerTasktask,longdelay)的注释:Schedulesthespecifiedtaskforexecutionafterthespecifieddelay。大意是在延时delay毫秒后执行task。并没有提到重复执行
schedule(TimerTasktask,longdelay,longperiod)的注释:Schedulesthespecifiedtaskforrepeatedfixed-delayexecution,beginningafterthespecifieddelay。大意是在延时delay毫秒后重复的执行task,周期是period毫秒。
这样问题就很明确schedule(TimerTasktask,longdelay)只执行一次,schedule(TimerTasktask,longdelay,longperiod)才是重复的执行。关键的问题在于程序员误以为schedule就是重复的执行,而没有仔细的研究API,一方面也是英文能力不够,浏览API的过程中不能很快的理解到含义。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对毛票票的支持。如果你想了解更多相关内容请查看下面相关链接