来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291469.html

 import java.util.concurrent.Callable;

 import java.util.concurrent.ExecutionException;

 import java.util.concurrent.ExecutorService;

 import java.util.concurrent.Executors;

 import java.util.concurrent.Future;

 import java.util.concurrent.ScheduledExecutorService;

 import java.util.concurrent.TimeUnit;

 /**

     在J2SE之前启动一个任务是通过调用Thread类的start方法来实现的,任务的提交和执行是同时进行的,如果想对任务的执行进行调度,或是控制同时执行的线程数量就需要额外的编写代码来完成.

     J2SE5.0提供了一个新的任务执行架构,可以轻松地高度和控制任务的执行,并且可以建立一个线程池来执行任务.

     实例介绍如何使用新的任务执行架构,运行Runnable和Callable任务,包括定时执行任务,按规律执行任务和停止任务.

 关键技术剖析:

     使用新的任务执行框架的关键技术如下:

     1.Executor服务对象是用来执行Runnable任务的,常用的方法如下:

       execute方法用于执行Runnable类型的任务.

     2.ExecutorService服务对象能执行和终止Callable任务,它继承了Executor,所以也能执行Runnable任务.常用的方法如下

       a) submit方法用来提交Callable或Runnable任务,并返回代表此任务的Future对象.

       b) invokeAll方法批处理任务集合,并返回一个代表这些任务的Future对象集合

       c) shutdown方法在完成自己已提交的任务后关闭服务,不再接受新任务.

       d) shutdownNow方法停止所有正在执行的任务并关闭服务.

       e) isTerminated测试是否所有任务都执行完毕了

       g) isShutdown测试是否该ExecutorService已被关闭

     3.ScheduledExecutorService服务对象继承ExecutorService,提供了按时间安排执行任务的功能.常用的方法如下:

       a)schedule(task,initDelay)方法安排所提交的Callable或Runnable任务在initDelay指定的时间后执行.

       b)scheduleAtFixedRate方法安排所提交的Runnable任务按指定的间隔重复执行.

       c)scheduleWithFixedDelay方法安排所提交的Runnable任务在每次执行完后,等待delay所指定的时间后重复执行.

     4.Executors类用来创建各种服务对象,常用的方法如下:

       a)callable(Runnable task)方法将Runnable的任务转化成Callable的任务.

       b)newSingleThreadExecutor方法产生一个ExecutorService对象,这个对象带有一个线程池,线程池的大小会根据需要调整,线程执行完任务后返回线程池,供执行下一次任务使用.

       c)newCachedThreadPool方法会产生一个ExecutorService对象,这个对象带有一个线程池,线程池的大小会根据需要调整,线程执行完任务后返回线程池,供执行下一次任务使用.

       d)newFixedThreadPool(int poolSize)方法产生一个ExecutorService对象,这个对象带有一个大小为poolSize的线程池,若任务数量大于poolSize,任务会被放在一个队列里顺序执行.

       e)newSingleThreadScheduledExecutor方法产生一个ScheduledExecutorService对象,这个对象的线程池大小为1,若任务多于一个,任务将按先后顺序执行.

       f)newScheduledThreadPool(int poolSize)方法产生一个ScheduledExecutorService对象,这个对象的线程池大小为poolSize,若任务数量大于poolSize,任务会在一个队列里等待执行.

 */

 public class ExecuteArch {

        /**该线程输出一行字符串*/

        public static class MyThread implements Runnable{

               public void run(){

                      System.out.println("Task repeating. " + System.currentTimeMillis());

                      try{

                             Thread.sleep(1000);

                      }catch(InterruptedException e){

                             System.out.println("Task interrupted. " + System.currentTimeMillis());

                      }

               }

        }

        /**该Callable结束另一个任务*/

        public static class MyCallable implements Callable{

               private Future future;

               public MyCallable(Future future){

                      this.future = future;

               }

               public String call(){

                      System.out.println("To cancell Task..." + System.currentTimeMillis());

                      this.future.cancel(true);

                      return "Task cancelled!";

               }

        }

        public static void main(String... args)throwsInterruptedException,ExecutionException{

               //产生一个ExcutorService对象,这个对象带有一个线程池,线程池的大小会根据需要调整

               //线程执行完任务后返回线程池,供执行下一次任务使用

               ExecutorService cachedService = Executors.newCachedThreadPool();

               Future myThreadFuture = cachedService.submit(new MyThread());

               Future myCallableFuture = cachedService.submit(newMyCallable(myThreadFuture));

               System.out.println(myCallableFuture.get());

               System.out.println("--------------------");

               //将Runnable任务转换成 Callable任务

               Callable myThreadCallable = Executors.callable(new MyThread());

               Future myThreadCallableFuture = cachedService.submit(myThreadCallable);

               //对于Runnable任务,转换成Callable任务后,也没有返回值

               System.out.println(myThreadCallableFuture.get());

               cachedService.shutdownNow();

               System.out.println("--------------------");

               //产生一个ExecutorService对象,这个对象带有一个大小为poolSize的线程池

               //若任务大于poolSize,任务会被放在一个queue里顺序执行

               ExecutorService fixedService = Executors.newFixedThreadPool(2);

               fixedService.submit(new MyThread());

               fixedService.submit(new MyThread());

               //由于线程池大小为2,所以后面的任务必须等待前面的任务执行完毕后才能被执行

               myThreadFuture = fixedService.submit(new MyThread());

               myThreadFuture = fixedService.submit(new MyCallable(myThreadFuture));

               System.out.println(myCallableFuture.get());

               fixedService.shutdown();

               System.out.println("--------------------");

               //产生一个ScheduleExecutorService对象,这个对象的线程池大小为poolSize

               //若任务数量大于poolSize,任务会在一个queue里等待执行

               ScheduledExecutorService fixedScheduledService = Executors.newScheduledThreadPool(2);

               MyThread task1 = new MyThread();

               //使用任务执行服务立即执行任务1,而且此后每隔2秒执行一次任务1

               myThreadFuture = fixedScheduledService.scheduleAtFixedRate(task1, 0, 2, TimeUnit.SECONDS);

               MyCallable task2 = new MyCallable(myThreadFuture);

               //使用任务执行服务等待5秒后执行任务2,执行它后将任务1关闭.

               myCallableFuture = fixedScheduledService.schedule(task2,5,TimeUnit.SECONDS);

               System.out.println(myCallableFuture.get());

               fixedScheduledService.shutdownNow();            

        }

 }

JDK5.0 特性-线程任务执行架构 ScheduledExecutorService的更多相关文章

  1. JDK5.0特性-线程 Callable和Future

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291466.html import java.util.concurrent.Callable ...

  2. JDK5.0特性,使用ProcessBuilder执行本地命令

    import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.File; import java.io.IO ...

  3. JDK5.0 特性-线程锁Lock

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291470.html import java.util.concurrent.Executor ...

  4. JDK5.0 特性线程 同步装置之CountDownLatch 同步装置之CyclicBarrier 线程 BlockingQueue

    来自:http://www.cnblogs.com/taven/category/475298.html import java.util.concurrent.CountDownLatch; imp ...

  5. JDK5.0 特性-线程同步装置之Semaphore

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291474.html import java.util.ArrayList; import j ...

  6. JDK5.0 特性-线程 Condition

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291471.html import java.util.concurrent.Executor ...

  7. JDK5.0 特性 监控与管理虚拟机

    来自:http://www.cnblogs.com/taven/archive/2011/12/17/2291465.html import java.lang.management.ClassLoa ...

  8. 集合框架-工具类-JDK5.0特性-函数可变参数

    1 package cn.itcast.p4.news.demo; 2 3 public class ParamterDemo { 4 5 public static void main(String ...

  9. 集合框架-工具类-JDK5.0特性-ForEach循环

    1 package cn.itcast.p4.news.demo; 2 3 import java.util.ArrayList; 4 import java.util.HashMap; 5 impo ...

随机推荐

  1. windows7文件共享 详细步骤 图解

    windows7文件共享详细步骤图解 http://wenku.baidu.com/link?url=PROjBfZ0KZFiAlgpb6sdaZBnSzFNTx3Ui_YXs5-IVoKBf2pPN ...

  2. cocos2d-x getVisibleOrigin

    getVisibleSize:表示获得视口(可视区域)的大小,如果DesignResolutionSize跟屏幕尺寸一样大,则getVisibleSize等于getWinSize.getVisible ...

  3. 再谈Linux内核中的RCU机制

    转自:http://blog.chinaunix.net/uid-23769728-id-3080134.html RCU的设计思想比较明确,通过新老指针替换的方式来实现免锁方式的共享保护.但是具体到 ...

  4. 如何生成安全的密码 Hash:MD5, SHA, PBKDF2, BCrypt 示例

    密码 Hash 值的产生是将用户所提供的密码通过使用一定的算法计算后得到的加密字符序列.在 Java 中提供很多被证明能有效保证密码安全的 Hash 算法实现,我将在这篇文章中讨论其中的部分算法. 需 ...

  5. 无耻之徒(美版)第一季/全集Shameless US迅雷下载

    第一季 Shameless Season 1 (2011)看点:本以为美版<无耻之徒>(Shameless)是小众剧(诸多儿童不宜),但是试播集98.2万的收视人次竟然创下了Showtim ...

  6. win7 64位系统及开发环境重装后的总结

    前言 话说来这家公司之后就一直使用这个系统,现在感觉这系统跑的实在是有点慢了,运行,调试各种浪费时间呀,不过也用了将近20个月了,这也可以说是我用的最久的一个系统了.由于新项目即将拉开战幕,所以自己趁 ...

  7. LINQ to XML 建立,读取,增,删,改

      LINQ to XML的出现使得我们再也不需要使用XMLDocument这样复杂的一个个的没有层次感的添加和删除.LINQ可以使的生成的XML文档在内存中错落有致.下面以一个小的例子说名LINQ ...

  8. perf使用示例2

    perf使用示例2 性能调优工具如 perf,Oprofile 等的基本原理都是对被监测对象进行采样,最简单的情形是根据 tick 中断进行采样,即在 tick 中断内触发采样点,在采样点里判断程序当 ...

  9. verilog语法实例学习(1)

    本文档中通过verilog实例来学习verilog语法.Verilog是一种硬件描述语言,它具有并发性和时序性.并发性是指不同硬件模块的同时操作,时序性是指信号的赋值或操作在时钟的边沿进行.由于作者本 ...

  10. FreePascal - Typhon在Windows10 X64下的使用问题!

    Typhon是CodeTyphon中的开发FreePascal的IDE工具. 在Windows10 X64中安装完CodeTyphon后,我们会发现有两套Typhon,分别对应32位和64位,32位可 ...