现在的位置: 首页 > 综合 > 正文

java5线程框架Executor 排程定时功能

2014年02月19日 ⁄ 综合 ⁄ 共 1595字 ⁄ 字号 评论关闭
 

 1,带有排程功能的例子(测试ScheduledExecutorService)。

 

   应用场景:延时5秒后每秒执行一次task1,task1打印一些信息;延时10秒后执行task2, task2用来取消task1的执行。

=============== ScheduledExecutorServiceTest.java  start ==================

package Executor;

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.ScheduledFuture;
import java.util.concurrent.TimeUnit;

public class ScheduledExecutorServiceTest {
  @SuppressWarnings("unchecked")
  public static void main(String[] args)

  throws InterruptedException, ExecutionException {

    //1 创建一个具有排程功能的线程池
    ScheduledExecutorService service = Executors.newScheduledThreadPool(2);

    //2 创建一个任务
    Runnable task1 = new Runnable() {
      public void run() {
        System.out.println("执行一次任务");
      }
    };

    //3 延时5秒后每秒执行一次task1;并返回一个Future 对象(通过Future对象可了解任务执行情况)
    final ScheduledFuture future1 = service.scheduleAtFixedRate(task1, 5, 1, TimeUnit.SECONDS);

    //4 生成一个可执行任务(该任务执行完毕可以返回结果 或者 抛出异常;而Runnable接口的run方法则不行)
    Callable task2 = new Callable() {
                        public String call() {
                 
                          future1.cancel(true);
                 
                          return "任务取消!";
                 
                        }
                      };
    //5 延时10秒后执行task2;并返回一个Future 对象(通过Future对象可了解任务执行情况)
    ScheduledFuture future2 = service.schedule(task2, 10, TimeUnit.SECONDS);
   
    //6 打印task2执行的结果
    System.out.println(future2.get());

    //7 关闭线程池
    service.shutdown();

  }
}

=============== ScheduledExecutorServiceTest.java  end ==================

输出如下:

执行一次任务
执行一次任务
执行一次任务
执行一次任务
执行一次任务
执行一次任务
任务取消!

抱歉!评论已关闭.