Timer 源码解读 (1) TimerTask简介

本文详细介绍了Java中Timer的工作原理,包括如何通过维护一个优先队列(Taskqueue)来存储和排序任务,以及如何通过TimerThread执行任务。同时,还深入探讨了TimerTask的不同状态及其转换过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转载请注明出处:http://blog.youkuaiyun.com/congqingbin/article/details/22997839


Timer通过维护一个优先队列(Taskqueue)来实现其任务存储排序功能,通过TimerThread来实现其任务执行功能


我们从类定义可以看出 :

public abstract class TimerTask implements Runnable 

(1 :abstract  虚基类,

(2: 实现Runnable接口,表示其表示的是一个任务,是一个要交给线程执行的任务

所以由Timer执行的任务 都是通过继承TimerTask来实现的


下面来看下TimerTask的几种状态:


    static final int VIRGIN = 0;   / / int state = VIRGIN;新创建一个TimerTask是初始值,意思就不多说了, man like it

    static final int SCHEDULED   = 1;   //当TimerTask背插进队列的时候,其状态就会变成SCHEDULED状态

    static final int EXECUTED    = 2;  //到TimerTask已经被执行完了时的状态值

    static final int CANCELLED   = 3; //任务被取消的

       public boolean cancel() {  //代码可以看出只有在任务插入队列但还没执行时取消任务才会返回true
        synchronized(lock) {
            boolean result = (state == SCHEDULED);
            state = CANCELLED;
            return result;
        }
    }



其他参数:

long nextExecutionTime; //程序首次执行时间,在任务初始化的时候被赋值 即在Timer.shedual( )中

 long period = 0; //任务执行周期

 如果为正值表示的是 fixed-rate  (根据上次任务开始执行的时间+固定值 来表示下回任务执行时间)

如果为负值表示的事 fixed-delay (根据上次任务完成的时间+固定值,来表示下回任务执行时间)






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值