`

java多线程 Callable 的实现

阅读更多
  1. import  java.util.concurrent.Callable;      
  2. import  java.util.concurrent.ExecutorService;      
  3. import  java.util.concurrent.Executors;      
  4. import  java.util.concurrent.Future;      
  5.      
  6. /** */ /**    
  7.  * Callable 和 Future接口    
  8.  * Callable是类似于Runnable的接口,实现Callable接口的类和实现Runnable的类都是可被其它线程执行的任务。    
  9.  * Callable和Runnable有几点不同:    
  10.  * (1)Callable规定的方法是call(),而Runnable规定的方法是run().    
  11.  * (2)Callable的任务执行后可返回值,而Runnable的任务是不能返回值的。    
  12.  * (3)call()方法可抛出异常,而run()方法是不能抛出异常的。    
  13.  * (4)运行Callable任务可拿到一个Future对象,    
  14.  * Future 表示异步计算的结果。它提供了检查计算是否完成的方法,以等待计算的完成,并检索计算的结果。    
  15.  * 通过Future对象可了解任务执行情况,可取消任务的执行,还可获取任务执行的结果。    
  16.  */      
  17. public   class  CallableAndFuture {      
  18.      
  19.      /** */ /**    
  20.      * 自定义一个任务类,实现Callable接口    
  21.      */      
  22.      public   static   class  MyCallableClass  implements  Callable{      
  23.          // 标志位      
  24.          private   int  flag =  0 ;      
  25.          public  MyCallableClass( int  flag){      
  26.              this .flag = flag;      
  27.         }      
  28.          public  String call()  throws  Exception{      
  29.              if  ( this .flag ==  0 ){      
  30.                  // 如果flag的值为0,则立即返回      
  31.                  return   "flag = 0" ;      
  32.             }       
  33.              if  ( this .flag ==  1 ){      
  34.                  // 如果flag的值为1,做一个无限循环      
  35.                  try  {      
  36.                      while  ( true ) {      
  37.                         System.out.println( "looping." );      
  38.                         Thread.sleep( 2000 );      
  39.                     }      
  40.                 }  catch  (InterruptedException e) {      
  41.                     System.out.println( "Interrupted" );      
  42.                 }      
  43.                  return   "false" ;      
  44.             }  else  {      
  45.                  // falg不为0或者1,则抛出异常      
  46.                  throw   new  Exception( "Bad flag value!" );      
  47.             }      
  48.         }      
  49.     }      
  50.           
  51.      public   static   void  main(String[] args) {      
  52.          // 定义3个Callable类型的任务      
  53.         MyCallableClass task1 =  new  MyCallableClass( 0 );      
  54.         MyCallableClass task2 =  new  MyCallableClass( 1 );      
  55.         MyCallableClass task3 =  new  MyCallableClass( 2 );      
  56.               
  57.          // 创建一个执行任务的服务      
  58.         ExecutorService es = Executors.newFixedThreadPool( 3 );      
  59.          try  {      
  60.              // 提交并执行任务,任务启动时返回了一个 Future对象,      
  61.              // 如果想得到任务执行的结果或者是异常可对这个Future对象进行操作      
  62.             Future future1 = es.submit(task1);      
  63.              // 获得第一个任务的结果,如果调用get方法,当前线程会等待任务执行完毕后才往下执行      
  64.             System.out.println( "task1: "  + future1.get());      
  65.                   
  66.             Future future2 = es.submit(task2);      
  67.              // 等待5秒后,再停止第二个任务。因为第二个任务进行的是无限循环      
  68.             Thread.sleep( 5000 );      
  69.             System.out.println( "task2 cancel: "  + future2.cancel( true ));      
  70.                   
  71.              // 获取第三个任务的输出,因为执行第三个任务会引起异常      
  72.              // 所以下面的语句将引起异常的抛出      
  73.             Future future3 = es.submit(task3);      
  74.             System.out.println( "task3: "  + future3.get());      
  75.         }  catch  (Exception e){      
  76.             System.out.println(e.toString());      
  77.         }      
  78.          // 停止任务执行服务      
  79.         es.shutdownNow();      
  80.     }      
  81. }  
分享到:
评论

相关推荐

    Java多线程Callable接口

    Runnable是执行工作的独立任务,但是它不返回任何值,如果你希望任务在完成时能够返回一个值,那么可以实现Callable接口而不是Runnable接口。在Java SE5中引入的Callable是一种具有类型参数的泛型,它的类型参数表示...

    Java多线程Callable和Future接口区别

    主要介绍了Java多线程Callable和Future接口区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

    java callable(多线程)

    callable用法

    Java多线程实现Callable接口

    本文给大家分享的是使用Java多线程来实现callable接口的方法,以及使用方法,另外还有一个网友的实例,希望能够对大家掌握Java多线程有所帮助。

    Java多线程Callable接口实现代码示例

    相信大家对Java编程中如何创建线程已经不陌生了,这篇文章就向朋友们介绍实现callable接口,具体实例详见正文。

    Java多线程之Callable接口的实现

    主要介绍了Java多线程之Callable接口的实现,Callable和Runnbale一样代表着任务,区别在于Callable有返回值并且可以抛出异常。感兴趣的小伙伴们可以参考一下

    java多线程编程 新api

    java 多线程编程 很实用 来自网上 1)包括新api介绍 2)新线程接口 Callable 和 Future 的讲解 3)线程同步知识

    计算机后端-Java-Java核心基础-第20章 多线程 18. 创建多线程的方式三:实现Callable接口.avi

    计算机后端-Java-Java核心基础-第20章 多线程 18. 创建多线程的方式三:实现Callable接

    java多线程学习

    java多线程学习,常见实现线程的方式,继承Thread类,实现Runnable接口,实现Callable接口

    java多线程Future和Callable类示例分享

    JAVA多线程实现方式主要有三种:继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。其中前两种方式线程执行完后都没有返回值,只有最后一种是带返回值的。今天我们...

    Java多线程-JDK5.0新增线程创建方式

    Java多线程--JDK5.0新增线程创建方式

    详解Java Callable接口实现多线程的方式

    主要介绍了详解Java Callable接口实现多线程的方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

    MultithreadingJava:来自Cave of Programming http的John Purcell的Java多线程课程代码

    课程内容: 1- Java 多线程:启动线程 2- Java 多线程:Volatile – 基本线程通信 ...13- Java 多线程:Callable 和 Future 14- Java 多线程:中断线程 15- Java 多线程:Swing 中的多线程与 SwingWorker

    多线程机制

    7、 浅析 Java Thread.join() : java多线程实现主线程等待所有子线程执行完毕 16 8、 线程运行中抛出异常的处理 19 9、 Callable 有返回值的线程 20 10、 Callable结合FutureTask的多线程使用(免打扰模式) 24

    java面试题_多线程(68题).pdf

    1. 什么是线程?...在Java Concurrency API中有哪些原⼦类(atomic classes)? 8. 什么是Executors框架? 9. 什么是阻塞队列?如何使⽤阻塞队列来实现⽣产者-消费者模型? 10. 什么是Callable和Future?

    个人总结的深入java多线程开发

    看完《think in java》多线程章节,自己写的多线程文档,还结合了其他的相关网络资料。 线程 一. 线程池 1)为什么要使用线程池 2 2)一个具有线程池的工作队列 3 3)使用线程池的风险: 4 4)有效使用线程池的原则 5...

    讲给女朋友听的java多线程(2万字深入理解多线程,有实例代码辅助理解)

    读完本文大概需要30分钟左右,本文有大量的实例代码和典型例题帮助大家理解java多线程。虽然多线程比较难以理解,仅靠一篇文章恐怕搞不定。但读完本文最起码能让你搞懂java多线程的70%以上,至于熟练运用,还是得...

    一篇文章弄懂Java多线程基础和Java内存模型

    文章目录一、多线程的生命周期及五种基本状态二、Java多线程的创建及启动1.继承Thread类,重写该类的run()方法2.通过实现Runnable接口创建线程类3.通过Callable和Future接口创建线程三、Java内存模型概念四、内存间...

    详细解读JAVA多线程实现的三种方式

    本篇文章主要介绍了详细解读JAVA多线程实现的三种方式,主要包括继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。有需要的可以了解一下。

Global site tag (gtag.js) - Google Analytics