Java定时器详解与实战示例

需积分: 31 4 下载量 9 浏览量 更新于2024-09-11 收藏 71KB DOC 举报
Java定时器是Java平台中一种用于在特定时间间隔或事件发生时执行任务的工具,这对于处理周期性或延迟执行的操作非常有用。本文档详细介绍了如何在Java中使用JDK内置的Timer和TimerTask类来实现定时任务。以下是主要知识点的详细讲解: 1. **核心组件**: - **Timer**:这是主要的定时器类,负责管理任务的调度。它是线程安全的,意味着可以同时处理多个任务,并且提供了多种`schedule()`方法以适应不同需求,如单次执行、定时重复执行等。 - **TimerTask**:这是一个抽象类,用于封装具体要执行的任务逻辑。开发者需要自定义一个子类并覆盖`run()`方法来实现任务功能。此外,`cancel()`方法用于取消任务,`scheduledExecutionTime()`方法则返回任务最近的执行时间。 2. **使用步骤**: - **创建任务**:首先,定义一个继承自`TimerTask`的类,重写`run()`方法来执行你的业务逻辑。 - **创建Timer实例**:实例化`Timer`对象,然后调用`schedule()`方法,传入任务对象以及执行的时间参数,如初始执行时间、延迟时间、重复间隔等。 3. **示例代码**: 文档中给出了一个使用`Timer`和`TimerTask`的简单示例,展示了如何创建一个名为`stu.timer`包下的类,导入必要的Java库后,定义一个`TimerTask`子类,并在其中实现`run()`方法。这个例子可能包含定时发送消息、定时清理缓存等常见的周期性操作。 4. **注意事项**: - `Timer`不提供实时保证,它依赖于`Object.wait(long)`,这意味着任务的执行可能存在不确定性。 - 可以通过`cancel()`方法取消未执行或正在执行的任务,`purge()`方法用于清除已取消的任务,以保持任务队列的整洁。 总结起来,Java定时器是实现异步任务处理的重要工具,尤其适用于不需要复杂状态管理、仅需周期性执行的场景。通过理解`Timer`和`TimerTask`的使用方式,开发者可以方便地在Java应用中添加定时任务,提升程序的灵活性和性能。
2015-10-14 上传
JAVA精确定时器,利用系统时间,使长期工作的误差稳定。 功能: ·可定时启动任务或直接启动任务 ·重复启动任务(时间间隔可在任务线程中改变,范围大于100ms,否则精度降低) 引用列表: ·import psn.razerpen.thread.AccuracyTimer; ·import psn.razerpen.thread.AccuracyTimerMission; ·import psn.razerpen.time.TimeStruct; 使用方法: //1·继承AccuracyTimerMission接口,创建一个类。 class MyTimer implements AccuracyTimerMission { //2·指定一个周期 int nDelay=1000; //3·重写run方法(如不需要使用新线程执行任务,也可留空) /** * 任务线程,本函数继承自Runnable */ @Override public void run() { System.out.println(new TimeStruct()); } //4·重写RunInCurrentThread(long nCurrentMilliSecond)方法。该方法接收当前时间,并返回下一次执行的时间。如果返回值不大于nCurrentMilliSecond则中止计时器。该方法必须重写。 /** * 接收当前时间的毫秒值,并返回下一次执行的毫秒值。如果返回的下一个时间早于当前时间,则退出 */ @Override public long RunInCurrentThread(long nCurrentMilliSecond) { return nCurrentMilliSecond+=nDelay; } } //5·创建主线程代码 public class TestTimer { public static void main(String[] args) throws InterruptedException { //6·创建一个AccuracyTimer对象,并指定一个任务。 AccuracyTimer at=new AccuracyTimer(new MyTimer()); //7·(可选)如果不需要在新线程中启动任务,则写 // at.SetNewThreadEnabled(false); //否则不写或者写 // at.SetNewThreadEnabled(true); //8·(可选)设定第一次启动的时间点SetNextMissionTime/SetNextMissionMilliSecond或延迟时间SetNextMissionMilliSecondFromNow //设置为当前这一分钟的第59秒后启动(不写此行则表示直接启动) at.SetNextMissionTime(Integer.MIN_VALUE, -1, -1, -1, -1, 59, 0); //9·启动定时器 at.Start(); //10·主线程继续 for(int i=0;i<60;++i){ Thread.sleep(1000); } //11·结束定时器 at.End(); } } 详见sample.razerpen.thread包中TestTimer及各代码文件中注释