摘要:类是一个定时任务类,该类实现了接口,而且是一个抽象类说明类是一个抽象类,由安排为一次执行或重复执行的任务。定时器实例有多种构造方法创建一个新计时器。
Timer 的定义
有且仅有一个后台线程对多个业务进行定时定频的调度。Timer 类可以保证多个线程可以共享单个 Timer 对象而无需进行外部同步,所以 Timer 类是线程安全的。
核心的两个类java.util.Timer 和 java.util.TimerTask
java.util.Timer。实际上是个线程,定时调度所拥有的 TimerTasks.
一个 TimerTask 实际上就是一个拥有 run() 方法的类,需要定时执行的代码放到run方法体内,TimerTask 一般是以匿名类的方式创建。
TimerTask 类是一个定时任务类,该类实现了 Runnable 接口,而且是一个抽象类
java.util.TimerTask
TimerTask 类是一个抽象类,由 Timer 安排为一次执行或重复执行的任务。
/* TimerTask 的类定义,为抽象类,并且实现了 Runnable 可以通过继承该类,来实现自己的定时任务。*/ public abstract class TimerTask implements Runnable
它有一个抽象方法 run() 方法,该方法用于执行相应计时器任务要执行的操作。因此每一个具体的任务类都必须继承 TimerTask,然后重写 run() 方法。
另外它还有两个非抽象的方法:
boolean cancel():取消此计时器任务。
long scheduledExecutionTime():返回此任务最近实际执行的安排执行时间。
java.util.Timer
注意:javax.swing 包中也有一个Timer类,如果import中用到swing包, 要注意名字的冲突。
Timer 定时器实例有多种构造方法:
Timer() : 创建一个新计时器。
Timer(boolean isDaemon) :创建一个新计时器,可以指定其相关的线程作为守护程序运行。
Timer(String name) :创建一个新计时器,其相关的线程具有指定的名称。
Timer(String name, boolean isDaemon):创建一个新计时器,其相关的线程具有指定的名称,并且可以指定作为守护程序运行。
Timer 定时器的schedule() (调度方法)
下面例子部分参数说明:
delay: 延迟执行的毫秒数,即在delay毫秒之后第一次执行
period:重复执行的时间间隔
/* time为Date类型:在指定时间执行一次。 */ timer.schedule(task, time); /* firstTime为Date类型,period为long 从firstTime时刻开始,每隔period毫秒执行一次。 */ timer.schedule(task, firstTime, period); /* delay 为 long类型:从现在起过delay毫秒执行一次 */ timer.schedule(task, delay) /* delay 为 long, period 为 long:从现在起过delay毫秒以后,每隔 period 毫秒执行一次。*/ timer.schedule(task, delay, period)
方法名称 schedule() 和 scheduleAtFixedRate() 的区别
schedule() 方法更注重保持间隔时间的稳定:保障每隔period时间可调用一次
scheduleAtFixedRate() 方法更注重保持执行频率的稳定:保障多次调用的频率趋近于period时间,如果任务执行时间大于period,会在任务执行之后马上执行下一次任务
scheduleAtFixedRate()
scheduleAtFixedRate(TimerTask task, Date firstTime, long period):安排指定的任务在指定的时间开始进行重复的固定速率执行。
scheduleAtFixedRate(TimerTask task, long delay, long period):安排指定的任务在指定的延迟后开始进行重复的固定速率执行。
实例代码说明MyTimerTask.java
作为一个需要调度的任务类。
import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.TimerTask; public class MyTimerTask extends TimerTask { private String name; public MyTimerTask(String inputName) { name = inputName; } @Override public void run() { Calendar calendar = Calendar.getInstance(); SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); System.out.println("current exec time is:"+ sf.format(calendar.getTime())); // 重写来自于 TimerTask 的 run() System.out.println("Current exec name is:" + name); } public String getName() { return name; } public void setName(String name) { this.name = name; } }
MyTimer.java
测试调度 MyTimerTask
import java.util.Timer; public class MyTimer { public static void main(String[] args) { // 创建一个 timer 实例 Timer timer = new Timer(); // 创建一个 MyTimerTask 实例 MyTimerTask myTimerTask = new MyTimerTask("No.1"); /* 通过 timer 定时定频调用 myTimerTask的业务逻辑 * 即第一次执行是在当前时间的两秒之后,之后每隔一秒执行一次 */ timer.schedule(myTimerTask, 2000L, 1000L); } }
输出结果
current exec time is:2018-06-05 14:35:22 Current exec name is:No.1 current exec time is:2018-06-05 14:35:23 Current exec name is:No.1 current exec time is:2018-06-05 14:35:24 Current exec name is:No.1schedule() 的用法
代码紧跟着上面的例子来做。
在时间等于或者超过 time 的时候执行,且执行一次
/* 获取当前时间,并设置成距离当前时间3秒之后的时间 * 比如当前时间为: 2018-06-05 23:59:58 * 则设置之后的时间为: 2018-06-06 00:00:00 */ Calendar calendar = Calendar.getInstance(); SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); System.out.println("current exec time is:"+ sf.format(calendar.getTime())); calendar.add(Calendar.SECOND, 3); /* 在时间等于或者超过 time 的时候执行,且执行一次 */ myTimerTask.setName("schedule1"); timer.schedule(myTimerTask, calendar.getTime());
输出的结果为:
current exec time is:2018-06-05 15:46:16 current exec time is:2018-06-05 15:46:19 Current exec name is:schedule1
时间等于或超过 time 的时候首次执行,之后每隔 period 毫秒重复执行一次 task
/* 获取当前时间,并设置成距离当前时间3秒之后的时间 * 比如当前时间为: 2018-06-05 23:59:58 * 则设置之后的时间为: 2018-06-06 00:00:00 */ Calendar calendar = Calendar.getInstance(); SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); System.out.println("current exec time is:"+ sf.format(calendar.getTime())); calendar.add(Calendar.SECOND, 3); /** * 时间等于或超过 time 的时候首次执行,之后每隔 period 毫秒重复执行一次 task */ myTimerTask.setName("schedule2"); timer.schedule(myTimerTask, calendar.getTime(), 3000L);
输出的结果为:
current exec time is:2018-06-05 15:54:32 current exec time is:2018-06-05 15:54:35 Current exec name is:schedule2 current exec time is:2018-06-05 15:54:38 Current exec name is:schedule2 current exec time is:2018-06-05 15:54:41 Current exec name is:schedule2
等待 delay 毫秒之后执行且执行一次 task
/** * 等待 delay 毫秒之后执行且执行一次 task */ myTimerTask.setName("schedule3"); timer.schedule(myTimerTask, 1000);
输出结果为:
current exec time is:2018-06-05 16:00:06 current exec time is:2018-06-05 16:00:07 Current exec name is:schedule3
等待 delay 毫秒之后,首次执行,并且之后每隔 period 毫秒重复执行一次 task
/** * 等待 delay 毫秒之后,首次执行,并且之后每隔 period 毫秒重复执行一次 task */ myTimerTask.setName("schedule4"); timer.schedule(myTimerTask, 1000, 3000);
输出结果为:
current exec time is:2018-06-05 16:01:36 current exec time is:2018-06-05 16:01:37 Current exec name is:schedule4 current exec time is:2018-06-05 16:01:40 Current exec name is:schedule4 current exec time is:2018-06-05 16:01:43 Current exec name is:schedule4scheduleAtFixedRate() 的用法
时间等于或者超过 time 时首次执行 task,之后每隔 period 毫秒重复执行一次
/* 获取当前时间,并设置成距离当前时间3秒之后的时间 * 比如当前时间为: 2018-06-05 23:59:58 * 则设置之后的时间为: 2018-06-06 00:00:00 */ Calendar calendar = Calendar.getInstance(); SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); System.out.println("current exec time is:"+ sf.format(calendar.getTime())); calendar.add(Calendar.SECOND, 3); /* 时间等于或者超过 time 时首次执行 task,之后每隔 period 毫秒重复执行一次 */ myTimerTask.setName("scheduleAtFixedRate1"); timer.scheduleAtFixedRate(myTimerTask, calendar.getTime(), 3000);
输出的结果为:
current exec time is:2018-06-05 16:11:48 current exec time is:2018-06-05 16:11:51 Current exec name is:scheduleAtFixedRate1 current exec time is:2018-06-05 16:11:54 Current exec name is:scheduleAtFixedRate1 current exec time is:2018-06-05 16:11:57 Current exec name is:scheduleAtFixedRate1
等待 delay 毫秒之后,首次执行,并且之后每隔 period 毫秒重复执行一次 task
/* 等待 delay 毫秒之后,首次执行,并且之后每隔 period 毫秒重复执行一次 task */ myTimerTask.setName("scheduleAtFixedRate2"); timer.scheduleAtFixedRate(myTimerTask, 1000, 3000);
输出的结果为:
current exec time is:2018-06-05 16:15:47 current exec time is:2018-06-05 16:15:48 Current exec name is:scheduleAtFixedRate2 current exec time is:2018-06-05 16:15:51 Current exec name is:scheduleAtFixedRate2 current exec time is:2018-06-05 16:15:54 Current exec name is:scheduleAtFixedRate2
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/71600.html
摘要:代码实例获取当前时间按照指定的格式输出设置成秒之前的时间使用来执行控制台输出方法总结我们可以看到实际的效果是在启动执行的时候,会立马执行次就是为了追赶已经过去的秒。 方法名称 schedule() 和 scheduleAtFixedRate() 的区别 两种情况看区别 首次计划执行的时间早于当前时间 比如说:当前时间是 11:06, 但是首次计划执行的时间应该为: 11:00 任务执行...
时间:2017年05月24日星期三说明:本文部分内容均来自慕课网。@慕课网:http://www.imooc.com教学示例源码:无个人学习源码:https://github.com/zccodere/s... 第一章:课程介绍 1-1 课程介绍 什么是定时任务调度 基于给定的时间点,给定的时间间隔或者给定的执行次数自动执行的任务 在Java中的定时调度工具 Timer:小弟,能实现日常60%的定...
摘要:本人邮箱欢迎转载转载请注明网址代码已经全部托管有需要的同学自行下载引言同步工具都讲的差不多了今天我们换一下口味讲一下定时任务吧理论延时后执行定时任务到达这个时间点执行定时任务延时后执行定时任务之后以为周期重复执行到达这个时间点执行定时任务之 本人邮箱: 欢迎转载,转载请注明网址 http://blog.csdn.net/tianshi_kcogithub: https://github...
摘要:设置一个定时器,定时询问服务器是否有信息,每次建立连接传输数据之后,链接会关闭。通过调用此程序提供的套接口接口与服务器端的套接口进行通信。 本文同步自我的博客园:http://hustskyking.cnblogs.com P.S: 各个平台中就 segmentFault 写博客体验最好了! web通信,一个特别大的topic,涉及面也是很广的。因最近学习了 javascript 中...
摘要:前言周末尝试了一下新的功能来封装一个组件,遇到一个,所以记录一下过程报错如下大概意思是组件已经卸载了,但在卸载之后还执行了一个对组件更新的操作,这是一个无效的操作,但它表示应用程序中存在内存泄漏。 showImg(https://segmentfault.com/img/bVbkD9k?w=1008&h=298); 前言 周末尝试了一下React新的hooks功能,来封装一个组件,...
阅读 1335·2021-11-15 11:45
阅读 3107·2021-09-27 13:36
阅读 2823·2019-08-30 15:54
阅读 967·2019-08-29 12:38
阅读 2880·2019-08-29 11:22
阅读 2969·2019-08-26 13:52
阅读 2000·2019-08-26 13:30
阅读 537·2019-08-26 10:37