当前位置:  编程技术>java/j2ee

java使用任务架构执行任务调度示例

    来源: 互联网  发布时间:2014-10-31

    本文导语:  代码如下:package com.yao; 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....

代码如下:

package com.yao;

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;

/**
 * 新的任务执行架构。
 * 在Java 5.0之前启动一个任务是通过调用Thread类的start()方法来实现的,
 * 任务的提于交和执行是同时进行的,如果你想对任务的执行进行调度,
 * 或是控制同时执行的线程数量就需要额外编写代码来完成。
 * 5.0里提供了一个新的任务执行架构使你可以轻松地调度和控制任务的执行,
 * 并且可以建立一个类似数据库连接池的线程池来执行任务。
 * 这个架构主要有三个接口和其相应的具体类组成。
 * 这三个接口是Executor, ExecutorService和ScheduledExecutorService。
 * (1)Executor接口:是用来执行Runnable任务的,它只定义一个方法:
 * execute(Runnable command):执行Ruannable类型的任务
 * (2)ExecutorService:继承了Executor的方法,并提供了执行Callable任务和中止任务执行的服务,
 * 其定义的方法主要有:
 * submit(task):可用来提交Callable或Runnable任务,并返回代表此任务的Future对象
 * invokeAll(collection of tasks):批处理任务集合,并返回一个代表这些任务的Future对象集合
 * shutdown():在完成已提交的任务后关闭服务,不再接受新任务
 * shutdownNow():停止所有正在执行的任务并关闭服务。
 * isTerminated():测试是否所有任务都执行完毕了。
 * isShutdown():测试是否该ExecutorService已被关闭
 * (3)ScheduledExecutorService:继承ExecutorService,提供了按时间安排执行任务的功能、
 * schedule(task, initDelay): 安排所提交的Callable或Runnable任务在initDelay指定的时间后执行。
 * scheduleAtFixedRate():安排所提交的Runnable任务按指定的间隔重复执行
 * scheduleWithFixedDelay():安排所提交的Runnable任务在每次执行完后,等待delay所指定的时间后重复执行。
 *
 * 通过Executors类来获得各种服务对象。
 * callable(Runnable task): 将Runnable的任务转化成Callable的任务
 * newSingleThreadExecutor: 产生一个ExecutorService对象,这个对象只有一个线程可用来执行任务,若任务多于一个,任务将按先后顺序执行。
 * newCachedThreadPool(): 产生一个ExecutorService对象,这个对象带有一个线程池,线程池的大小会根据需要调整,线程执行完任务后返回线程池,供执行下一次任务使用。
 * newFixedThreadPool(int poolSize):产生一个ExecutorService对象,这个对象带有一个大小为poolSize的线程池,若任务数量大于poolSize,任务会被放在一个queue里顺序执行。
 * newSingleThreadScheduledExecutor:产生一个ScheduledExecutorService对象,这个对象的线程池大小为1,若任务多于一个,任务将按先后顺序执行。
 * newScheduledThreadPool(int poolSize): 产生一个ScheduledExecutorService对象,这个对象的线程池大小为poolSize,若任务数量大于poolSize,任务会在一个queue里等待执行
 */
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!";
  }
 }

 /**
  * @param args
  * @throws ExecutionException
  * @throws InterruptedException
  */
 public static void main(String[] args) throws InterruptedException,
   ExecutionException {
  // 产生一个ExecutorService对象,这个对象带有一个线程池,线程池的大小会根据需要调整,
  // 线程执行完任务后返回线程池,供执行下一次任务使用。
  ExecutorService cachedService = Executors.newCachedThreadPool();
  Future myThreadFuture = cachedService.submit(new MyThread());
  Future myCallableFuture = cachedService.submit(new MyCallable(
    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());
  myCallableFuture = fixedService.submit(new MyCallable(myThreadFuture));
  System.out.println(myCallableFuture.get());
  fixedService.shutdownNow();
  System.out.println("-----------------");

  // 产生一个ScheduledExecutorService对象,这个对象的线程池大小为poolSize,
  // 若任务数量大于poolSize,任务会在一个queue里等待执行
  ScheduledExecutorService fixedScheduledService = Executors
    .newScheduledThreadPool(2);
  // 新建任务1
  MyThread task1 = new MyThread();
  // 使用任务执行服务立即执行任务1,而且此后每隔2秒执行一次任务1。
  myThreadFuture = fixedScheduledService.scheduleAtFixedRate(task1, 0, 2,
    TimeUnit.SECONDS);
  // 新建任务2
  MyCallable task2 = new MyCallable(myThreadFuture);
  // 使用任务执行服务等待5秒后执行任务2,执行它后会将任务1关闭。
  myCallableFuture = fixedScheduledService.schedule(task2, 5,
    TimeUnit.SECONDS);
  System.out.println(myCallableFuture.get());
  fixedScheduledService.shutdownNow();
 }
}


    
 
 

您可能感兴趣的文章:

  • 使用java执行定时任务示例
  • java自定义任务类定时执行任务示例 callable和future接口使用方法
  • Java任务调度 JDRing
  • Java任务调度 jconch
  • Java任务调度 Gos4j
  • 用java做个带任务栏托盘的程序该如何做阿
  • JAVA能写个程序一般的window程序在任务栏挂一个图标么?
  • Java任务调度 Fulcrum Scheduler
  • java定时任务的实现方法
  • java多线程并发executorservice(任务调度)类
  • 我对JAVA一窍不通,可惜别人却给我一个Java的project,要我做一个安装程序,请问哪里有JAVA INSTALLER下载,而且我要不要安装java的sdk才能完成此项任务?
  • 感觉java胜任大型企业级的任务绰绰有余了,可是面对一些小些企业的解决方案听的并不是很多,所以我希望听听各位的看法(如果实际解决过这
  • Java定时任务的三种实现方法
  • java中 spring 定时任务 实现代码
  • andriod下java socket网络编程:java socket客户端服务端代码示例
  • 输出java进程的jstack信息示例分享 通过线程堆栈信息分析java线程
  • java Servlet实现Session创建存取以及url重写代码示例
  • java 四舍五入使java保留2位小数示例讲解
  • java进行error捕获和处理示例(java异常捕获)
  • java去除集合中重复元素示例分享 java去除重复
  • java读取csv文件示例分享(java解析csv文件)
  • java求三个数的最大值的示例分享
  • java生成字母数字组合的随机数示例 java生成随机数
  • java实现网页解析示例
  • java协变返回类型使用示例
  • java自定义枚举转换器示例
  • java向文件末尾添加内容示例分享
  • java正则表达式获取url的host示例
  • java使用正则表达校验手机号码示例(手机号码正则)
  • java实现jframe透明窗体示例
  • java的split方法使用示例
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Java作业调度 Oddjob
  • 关于java线程调度优先级
  • java实现操作系统的短进程作业调度示例分享
  • java定时调度器(Quartz)使用实例
  • java命名空间java.sql类types的类成员方法: java_object定义及介绍
  • 我想学JAVA ,是买THINK IN JAVA 还是JAVA2核心技术:卷1 好???
  • java命名空间java.awt.datatransfer类dataflavor的类成员方法: imageflavor定义及介绍
  • 请问Java高手,Java的优势在那里??,Java主要适合于开发哪类应用程序
  • java命名空间java.lang.management类managementfactory的类成员方法: getcompilationmxbean定义及介绍
  • 如何将java.util.Date转化为java.sql.Date?数据库中Date类型对应于java的哪个Date呢
  • java命名空间java.lang.management接口runtimemxbean的类成员方法: getlibrarypath定义及介绍
  • 谁有电子版的《Java编程思想第二版(Thinking in java second)》和《Java2编程详解(special edition java2)》?得到给分
  • java命名空间java.lang.management接口runtimemxbean的类成员方法: getstarttime定义及介绍
  • 本人想学java,请问java程序员的待遇如何,和java主要有几个比较强的方向
  • java命名空间java.awt.datatransfer类dataflavor的类成员方法: stringflavor定义及介绍
  • 新年第一天,让我们讨论一下未来一年JAVA的发展趋势! 个人认为,JAVA将主要朝ERP和JAVA手机方面发展!
  • java命名空间java.security类keystore的类成员方法: getdefaulttype定义及介绍
  • 我想学Java,但不知道Java的实用的开发工具有那些,Java主要用在哪些方面,EJB到底是什么东西??
  • java命名空间java.lang.management接口runtimemxbean的类成员方法: getclasspath定义及介绍
  • redhat7.3下,java程序打印中文直接用java命令执行正常,用crontab执行java命令为乱码
  • java命名空间java.awt.datatransfer类dataflavor的类成员方法: javaserializedobjectmimetype定义及介绍
  • 各位学java的朋友,学java的未来是什么,你们学java都用来开发什么项目啊!来者给分!!
  • java命名空间java.awt.datatransfer类dataflavor的类成员方法: javafilelistflavor定义及介绍
  • 请问java程序中的import为什么有的用java.….*,而有的又用java.….…,有什么区别吗?
  • java命名空间java.lang.management接口runtimemxbean的类成员方法: getvmname定义及介绍
  • 简单说说Java SE、Java EE、Java ME三者之间的区别


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3