java.util.concurrent中的Callable,Future
来源:互联网 发布:js正则表达式验证邮箱 编辑:程序博客网 时间:2024/06/06 04:33
Java中存在Runnable、Callable、Future、FutureTask这几个与线程相关的类或者接口,在Java中也是比较重要的几个概念,我们通过下面的简单示例来了解一下它们的作用于区别。
Runnable
其中Runnable应该是我们最熟悉的接口,它只有一个run()函数,用于将耗时操作写在其中,该函数没有返回值。然后使用某个线程去执行该runnable即可实现多线程,Thread类在调用start()函数后就是执行的是Runnable的run()函数。Runnable的声明如下 :
Callable
Callable与Runnable的功能大致相似,Callable中有一个call()函数,但是call()函数有返回值,而Runnable的run()函数不能将结果返回给客户程序。Callable的声明如下 :
可以看到,这是一个泛型接口,call()函数返回的类型就是客户程序传递进来的V类型。Future
Executor就是Runnable和Callable的调度容器,Future就是对于具体的Runnable或者Callable任务的执行结果进行
取消、查询是否完成、获取结果、设置结果操作。get方法会阻塞,直到任务返回结果(Future简介)。Future声明如下 :
FutureTask
FutureTask则是一个RunnableFuture<V>,而RunnableFuture实现了Runnbale又实现了Futrue<V>这两个接口,
RunnableFuture
另外它还可以包装Runnable和Callable<V>, 由构造函数注入依赖。
可以看到,Runnable注入会被Executors.callable()函数转换为Callable类型,即FutureTask最终都是执行Callable类型的任务。该适配函数的实现如下 :
RunnableAdapter适配器
由于FutureTask实现了Runnable,因此它既可以通过Thread包装来直接执行,也可以提交给ExecuteService来执行。
并且还可以直接通过get()函数获取执行结果,该函数会阻塞,直到结果返回。因此FutureTask既是Future、
Runnable,又是包装了Callable( 如果是Runnable最终也会被转换为Callable ), 它是这两者的合体。
简单示例
输出结果
- java.util.concurrent中的Callable,Future
- java.util.concurrent包(4)——Callable和Future
- Java.util.concurrent 包 使用Future,Callable实现抢答模式
- java.util.concurrent.Callable, Runnable, Future,ExecutorService介绍
- java.util.concurrent.Callable
- java.util.concurrent.Callable
- java.util.concurrent.Future
- java.util.concurrent.Callable<V>
- java.util.concurrent.Future<V>
- java.util.concurrent.Future浅析
- 多线程之Future和Callable【高性能应用场景java.util.concurrent】
- java.util.concurrent.Future 类基础
- java.util.concurrent.Future 类基础
- java.util.concurrent.Future 类基础
- Java中的Callable和Future
- Java中的Callable和Future
- Java中的Callable和Future
- Java并发包Concurrent下Callable和Future实战
- CUDA 7.5 安装及配置(WIN7 VS2013)
- Tomcat使用Spring管理对象出现HashMap死循环的问题
- 三人行-某栈-两周心得
- echarts实现气泡图(气泡之间不叠加)
- C++利用链表将英文单词排序
- java.util.concurrent中的Callable,Future
- Web Service (011---webservice自定义拦截器)
- 分治问题,求最大子序列HDU1231
- 传奇大亨———拉里·埃里森
- c程序设计p82-p83
- QTableWidget中表格显示图片
- MySQL 事务问题及隔离级别
- 随机森林算法学习(RandomForest)
- 洛谷P2680 运输计划(NOIp2015)(BZOJ4326)