zoukankan      html  css  js  c++  java
  • java.util.Timer

    java.util.Timer定时器,实际上是个线程,定时调度所拥有的TimerTasks。 
    一个TimerTask实际上就是一个拥有run方法的类,需要定时执行的代码放到run方法体内,TimerTask一般是以匿名类的方式创建。

    java.util.Timer timer = new java.util.Timer(true); 
    // true 说明这个timer以daemon方式运行(优先级低, 
    // 程序结束timer也自动结束),注意,javax.swing 
    // 包中也有一个Timer类,如果import中用到swing包, 
    // 要注意名字的冲突。 
    
    TimerTask task = new TimerTask() { 
    public void run() { 
    ... //每次需要执行的代码放到这里面。 
    } 
    }; 
    
    //以下是几种调度task的方法: 
    
    timer.schedule(task, time); 
    // time为Date类型:在指定时间执行一次。 
    
    timer.schedule(task, firstTime, period); 
    // firstTime为Date类型,period为long 
    // 从firstTime时刻开始,每隔period毫秒执行一次。 
    
    timer.schedule(task, delay) 
    // delay 为long类型:从现在起过delay毫秒执行一次 
    
    timer.schedule(task, delay, period) 
    // delay为long,period为long:从现在起过delay毫秒以后,每隔period 
    // 毫秒执行一次。

    下面是一个完整的例子,由两个类组成,一个定制任务,一个调用java.util.Timer 

    定制任务:

    import java.util.Timer;
    
    public class TimerTaskTest extends java.util.TimerTask{
    
    @Override
    public void run() {
       // TODO Auto-generated method stub
       System.out.println("start");
    }
    }

    调用java.util.Timer 

    import java.util.Timer;
    
    public class Test {
    public static void main(String[] args){
       Timer timer = new Timer();
       timer.schedule(new TimerTaskTest(), 1000, 2000);
    }
    }

    Timer是调度控制器,TimerTask是可调度的任务:

    原理:

         其基本处理模型是单线程调度的任务队列模型,Timer不停地接受调度任务,所有任务接受Timer调度后加入TaskQueue,TimerThread不停地去TaskQueue中取任务来执行.

     从图上不难看出,这就是生产者--消费者模型的一种特例:多生产者,单消费者模型。

         此种消息队列实现方式在浏览器中的编程模型中也有类似的实现,javascript中的定时执行函数setTimeout(expression,milliseconds)也是基于此种原理实现的。

         此种方式的不足之处为当某个任务执行时间较长,以致于超过了TaskQueue中下一个任务开始执行的时间,会影响整个任务执行的实时性。为了提高实时性,可以采用多个消费者一起消费来提高处理效率,避免此类问题的实现。

    http://www.cnblogs.com/jinspire/archive/2012/02/10/2345256.html

     

     

  • 相关阅读:
    leetcode-832-Flipping an Image
    leetcode-830-Positions of Large Groups
    leetcode-824-Goat Latin(字符串的处理)
    leetcode-821-Shortest Distance to a Character
    leetcode-819-Most Common Word(词频统计)
    HDU 4729 An Easy Problem for Elfness(树链剖分边权+二分)
    python爬虫(1)——正则表达式
    利用MySQL之federated引擎实现DBLink功能
    HTTPS原理及流程
    NIO、多路复用的终极奥义
  • 原文地址:https://www.cnblogs.com/youxin/p/2710620.html
Copyright © 2011-2022 走看看