Timer 源码解读 (1) TimerTask简介

来源:互联网 发布:泰森多边形算法 编辑:程序博客网 时间:2024/05/07 14:04

转载请注明出处:http://blog.csdn.net/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 (根据上次任务完成的时间+固定值,来表示下回任务执行时间)






0 0
原创粉丝点击