Runnable和Callable描述的都是抽象的计算任务。这些任务通常是有范围的,即都有一个明确的起始点,并且最终会结束。Executor执行的任务有4个生命周期阶段:创建、提交、开始和完成。由于有些任务可能要执行很长的时间,因此通常希望能够取消这些任务。在Executor框架中,已提交但尚未开始的任务可以取消,但对于那些已经开始执行的任务,只有当它们能响应中断时,才能取消。取消一个已经完成的任务不会有任何影响。
在此为了分析Callable和Future的用法,摘录了http://www.cnblogs.com/taven/archive/2011/12/17/2291466.html
import java.util.concurrent.Callable; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.Future; /** 从本节开始,主要介绍J2SE5.0与线程相关的新特性,新的线程类主要集中在java.util.concurrent 包中,本节实例将介绍如何使用java.util.concurrent.Callable和java.util.concurrent.Future类, 用Callable定义一个任务并启动它,然后用它的Future获取输出结果并停止它. 关键技术剖析: 关于Callable和Future类的关键技术如下: 1.Callable是类似于Runnable的接口,实现Callable接口的类和实现Runable的类都是可被其他线程 执行的任务. 2.Callable和Runnable的区别如下: 1)Callable定义的方法是call,而Runnable定义的方法是run. 2)Callable的call方法可以有返回值,而Runnable的run方法不能有返回值 3)Callable的call方法可抛出异常,而Runnable的run方法不能抛出异常 3.Future表示异步计算的结果,它提供了检查计算是否完成的方法,以等待计算的完成,并检索计算的 结果.Future的cancel方法取消任务的执行,有一个布尔参数,参数为true表示立即中断任务的执行,参数 为false表示允许正在运行的任务运行完成.Future的get方法等待计算完成,获取计算结果. */ public class CallableAndFuture { /**自定义一个任务类,实现Callable接口*/ public static class MyCallableClass implements Callable{ private int flag = 0; public MyCallableClass(int flag){ this.flag = flag; } public String call() throws Exception{ if(this.flag == 0){ return "flag = 0";//如果flag的值为0,则立即返回 } if(this.flag == 1){ //如果flag的值为1,做一个无限循环 try{ while(true){ System.out.println("looping..."); Thread.sleep(2000); } }catch(InterruptedException e){ System.out.println("Interrupted"); } return "false"; }else{ throw new Exception("Bad flag value!");//flag不为1或0,则抛出异常 } } } public static void main(String... args){ //定义3个Callable类型的任务 MyCallableClass task1 = new MyCallableClass(0); MyCallableClass task2 = new MyCallableClass(1); MyCallableClass task3 = new MyCallableClass(2); //创建一个执行任务的服务 ExecutorService es = Executors.newFixedThreadPool(3); try{ //提交并执行任务,任务启动时返回了一个Future对象 //如果想得到任务执行的结果或者是异常可对这个Future对象进行操作 Future future1 = es.submit(task1); //获得第一个任务的结果,如果调用get方法,当前线程会等待任务执行完毕后才往下执行 System.out.println("task1: " + future1.get()); Future future2 = es.submit(task2); //等待5秒后,再停止第二个任务,因为第二个任务进行的是无限循环 Thread.sleep(5000); System.out.println("task2 cancel: " + future2.cancel(true)); //获取第三个任务的输出,因为执行第三个任务会引起异常 //所以下面的语句将引起异常的输出 Future future3 = es.submit(task3); System.out.println("task3: " + future3.get()); }catch(Exception e){ System.out.println(e.toString()); } es.shutdown();//立即停止任务执行服务 } }
相关推荐
《java jdk 7学习笔记》适合java的初中级读者,以及广大java应用开发人员。 作译者 林信良(网名:良葛格) 学历:台湾大学电机工程学系 经历:台湾升阳教育训练技术顾问、专业讲师,oracle授权训练中心讲师 ...
### Java学习笔记知识点总结 #### 一、JVM与内存管理 ...通过以上知识点的总结,我们可以清晰地了解到Java学习笔记中涵盖的主要内容和技术细节,有助于深入理解和掌握Java语言及相关的开发技术。
Java 作为一门广泛使用的编程语言,在软件开发领域占据了极其重要的地位。JDK 1.7(也称为Java 7)是Java发展史上的一个重要里程碑,它不仅继承了前几个版本的优点,还引入了许多新的功能和改进。 #### 二、Java ...
### 深入Java虚拟机JVM类加载学习笔记 #### 一、Classloader机制解析 在Java虚拟机(JVM)中,类加载器(ClassLoader)是负责将类的`.class`文件加载到内存中的重要组件。理解类加载器的工作原理对于深入掌握JVM以及...
#### 3.1 命令行方式(Windows环境) 在 Windows 环境下,可以通过命令行来启动 Essbase。具体的命令行格式可能如下: ```bat essbase -s <servername> -p ``` 其中 `<servername>` 是服务器名称或 IP 地址,`...
- **3.2.2 所需软件**:需要安装JDK(Java Development Kit),因为Hadoop是用Java编写的。 - **3.2.3 安装软件**:下载最新的Hadoop二进制包,并解压缩到指定目录。 **3.3 下载** 从Apache官方网站下载最新的...
### 西电分布式计算课程(PPT总结版)笔记知识点详解 #### 一、通信技术 **1.1 分布式计算基础** - **通信技术的重要性:** 在分布式计算领域,节点之间的高效通信是实现高性能计算的核心。文档重点介绍了几种...
1.1 Spark概述:Spark由加州大学伯克利分校AMPLab开发,旨在提供比Hadoop MapReduce更快的数据处理速度。它通过内存计算和优化的 DAG 执行引擎实现了高效的计算性能。 1.2 Spark架构:Spark由Driver、Executor和...
- **编程语言**:C/C++、Java、Python等。 - **软件开发流程**:需求分析、设计、编码、测试、维护等阶段。 #### 四、微型计算机系统设计与实现 **4.1 微处理器设计** - **微处理器设计原则**:高性能、低功耗、可...
- **Python和Java接口**:除了C++外,OpenCV还为Python和Java提供了接口,使得这些语言的用户也能利用CUDA进行高性能图像处理。 #### 六、版本控制与GitHub GitHub是一个流行的代码托管平台,支持使用Git进行版本...