Java线程(七):Callable和Future

转载 2015年07月10日 10:03:22

    接着上一篇继续并发包的学习,本篇说明的是Callable和Future,它俩很有意思的,一个产生结果,一个拿到结果。

        Callable接口类似于Runnable,从名字就可以看出来了,但是Runnable不会返回结果,并且无法抛出返回结果的异常,而Callable功能更强大一些,被线程执行后,可以返回值,这个返回值可以被Future拿到,也就是说,Future可以拿到异步执行任务的返回值,下面来看一个简单的例子:

  1. public class CallableAndFuture {  
  2.     public static void main(String[] args) {  
  3.         Callable<Integer> callable = new Callable<Integer>() {  
  4.             public Integer call() throws Exception {  
  5.                 return new Random().nextInt(100);  
  6.             }  
  7.         };  
  8.         FutureTask<Integer> future = new FutureTask<Integer>(callable);  
  9.         new Thread(future).start();  
  10.         try {  
  11.             Thread.sleep(5000);// 可能做一些事情  
  12.             System.out.println(future.get());  
  13.         } catch (InterruptedException e) {  
  14.             e.printStackTrace();  
  15.         } catch (ExecutionException e) {  
  16.             e.printStackTrace();  
  17.         }  
  18.     }  
  19. }  
        FutureTask实现了两个接口,Runnable和Future,所以它既可以作为Runnable被线程执行,又可以作为Future得到Callable的返回值,那么这个组合的使用有什么好处呢?假设有一个很耗时的返回值需要计算,并且这个返回值不是立刻需要的话,那么就可以使用这个组合,用另一个线程去计算返回值,而当前线程在使用这个返回值之前可以做其它的操作,等到需要这个返回值时,再通过Future得到,岂不美哉!这里有一个Future模式的介绍:http://openhome.cc/Gossip/DesignPattern/FuturePattern.htm

        下面来看另一种方式使用Callable和Future,通过ExecutorService的submit方法执行Callable,并返回Future,代码如下:

  1. public class CallableAndFuture {  
  2.     public static void main(String[] args) {  
  3.         ExecutorService threadPool = Executors.newSingleThreadExecutor();  
  4.         Future<Integer> future = threadPool.submit(new Callable<Integer>() {  
  5.             public Integer call() throws Exception {  
  6.                 return new Random().nextInt(100);  
  7.             }  
  8.         });  
  9.         try {  
  10.             Thread.sleep(5000);// 可能做一些事情  
  11.             System.out.println(future.get());  
  12.         } catch (InterruptedException e) {  
  13.             e.printStackTrace();  
  14.         } catch (ExecutionException e) {  
  15.             e.printStackTrace();  
  16.         }  
  17.     }  
  18. }  
        代码是不是简化了很多,ExecutorService继承自Executor,它的目的是为我们管理Thread对象,从而简化并发编程,Executor使我们无需显示的去管理线程的生命周期,是JDK 5之后启动任务的首选方式。

        执行多个带返回值的任务,并取得多个返回值,代码如下:

  1. public class CallableAndFuture {  
  2.     public static void main(String[] args) {  
  3.         ExecutorService threadPool = Executors.newCachedThreadPool();  
  4.         CompletionService<Integer> cs = new ExecutorCompletionService<Integer>(threadPool);  
  5.         for(int i = 1; i < 5; i++) {  
  6.             final int taskID = i;  
  7.             cs.submit(new Callable<Integer>() {  
  8.                 public Integer call() throws Exception {  
  9.                     return taskID;  
  10.                 }  
  11.             });  
  12.         }  
  13.         // 可能做一些事情  
  14.         for(int i = 1; i < 5; i++) {  
  15.             try {  
  16.                 System.out.println(cs.take().get());  
  17.             } catch (InterruptedException e) {  
  18.                 e.printStackTrace();  
  19.             } catch (ExecutionException e) {  
  20.                 e.printStackTrace();  
  21.             }  
  22.         }  
  23.     }  
  24. }        

        其实也可以不使用CompletionService,可以先创建一个装Future类型的集合,用Executor提交的任务返回值添加到集合中,最后遍历集合取出数据,代码略。        

        本文来自:高爽|Coder,原文地址:http://blog.csdn.net/ghsau/article/details/7451464,转载请注明。

多线程Callable和Future

---------------------- android培训、java培训、期待与您交流! ----------------------   关于多线程Callable和Future    ...
  • zhuangxingrui86
  • zhuangxingrui86
  • 2012年08月14日 16:43
  • 6504

Java 7之多线程线程池 - Callable和Future

Callable接口代表一段可以调用并返回结果的代码;Future接口表示异步任务,是还没有完成的任务给出的未来结果。所以说Callable用于产生结果,Future用于获取结果。     Java...
  • mazhimazh
  • mazhimazh
  • 2014年02月16日 18:55
  • 15763

Java并发编程:Callable和Future使用

在Java中,创建线程一般有两种方式,一种是继承Thread类,一种是实现Runnable接口。然而,这两种方式的缺点是在线程任务执行结束后,无法获取执行结果。我们一般只能采用共享变量或共享存储区以及...
  • u013405574
  • u013405574
  • 2016年04月06日 13:32
  • 2753

使用Callable与Future来创建启动线程

使用Callable与Future来创建启动线程   1.创建Callable的实现类,并冲写call()方法,该方法为线程执行体,并且该方法有返回值   2.创建Callable...
  • autumn20080101
  • autumn20080101
  • 2016年03月04日 21:45
  • 489

Java多线程之Callable和Future接口的实现

Callable和Future     Callable接口定义了一个call方法可以作为线程的执行体,但call方法比run方法更强大:     A、call方法可以有返回值 ...
  • youzai24
  • youzai24
  • 2012年11月28日 17:15
  • 1351

java多线程Future和Callable类的解释与使用

java多线程Future和Callable类的解释与使用
  • jiangfullll
  • jiangfullll
  • 2014年07月09日 17:57
  • 1112

Java 多线程 callable future实例

Java 多线程 callable future实例
  • Tc_To_Top
  • Tc_To_Top
  • 2016年09月17日 20:41
  • 992

Java 多线程设置线程超时时间之 Callable接口和Future接口 线程超时控制

来源URL:http://blog.csdn.net/zlj526/article/details/40782027 Callable接口和Future接口介绍         在Java中,如...
  • u013160024
  • u013160024
  • 2017年02月11日 19:28
  • 1029

Java之Callable 和 Future实现线程等待

1、Callable: public interface Callable 返回结果并且可能抛出异常的任务。实现者定义了一个不带任何参数的叫做 call 的方法。 Callable 接口类似于...
  • shihuacai
  • shihuacai
  • 2013年04月26日 21:06
  • 4327

java利用线程池(ExecutorService)配合Callable和Future实现执行方法超时的阻断

今天在项目开发中需要用到对执行方法加上时间控制,如果方法执行过长则跳出执行,废话不说,直接上代码,用的是线程池配合Callable和Future方式对执行方法的超时阻断。希望各位牛人指正  ...
  • dupeng41255
  • dupeng41255
  • 2015年06月09日 13:47
  • 1163
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Java线程(七):Callable和Future
举报原因:
原因补充:

(最多只允许输入30个字)