`
sunhuaer123
  • 浏览: 6327 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

Java并行开发笔记3.1

    博客分类:
  • java
阅读更多

 

  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 7,前期版本累计销量5万册)

     《java jdk 7学习笔记》适合java的初中级读者,以及广大java应用开发人员。 作译者 林信良(网名:良葛格) 学历:台湾大学电机工程学系 经历:台湾升阳教育训练技术顾问、专业讲师,oracle授权训练中心讲师 ...

    阿里P8 架构师整理Java学习笔记.pdf

    ### Java学习笔记知识点总结 #### 一、JVM与内存管理 ...通过以上知识点的总结,我们可以清晰地了解到Java学习笔记中涵盖的主要内容和技术细节,有助于深入理解和掌握Java语言及相关的开发技术。

    Java jdk1.7学习笔记pdf

    Java 作为一门广泛使用的编程语言,在软件开发领域占据了极其重要的地位。JDK 1.7(也称为Java 7)是Java发展史上的一个重要里程碑,它不仅继承了前几个版本的优点,还引入了许多新的功能和改进。 #### 二、Java ...

    深入Java虚拟机JVM类加载学习笔记

    ### 深入Java虚拟机JVM类加载学习笔记 #### 一、Classloader机制解析 在Java虚拟机(JVM)中,类加载器(ClassLoader)是负责将类的`.class`文件加载到内存中的重要组件。理解类加载器的工作原理对于深入掌握JVM以及...

    Essbase开发笔记

    #### 3.1 命令行方式(Windows环境) 在 Windows 环境下,可以通过命令行来启动 Essbase。具体的命令行格式可能如下: ```bat essbase -s <servername> -p ``` 其中 `<servername>` 是服务器名称或 IP 地址,`...

    hadoop 笔记

    - **3.2.2 所需软件**:需要安装JDK(Java Development Kit),因为Hadoop是用Java编写的。 - **3.2.3 安装软件**:下载最新的Hadoop二进制包,并解压缩到指定目录。 **3.3 下载** 从Apache官方网站下载最新的...

    西电分布式计算课程(PPT总结版)笔记

    ### 西电分布式计算课程(PPT总结版)笔记知识点详解 #### 一、通信技术 **1.1 分布式计算基础** - **通信技术的重要性:** 在分布式计算领域,节点之间的高效通信是实现高性能计算的核心。文档重点介绍了几种...

    spark:spark学习笔记

    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进行版本...

Global site tag (gtag.js) - Google Analytics