Runnable、Callable、Executor、Future、FutureTask关系解读
来源:互联网 发布:星际战甲嗜血冲动算法 编辑:程序博客网 时间:2024/04/28 05:02
在再度温习Java5的并发编程的知识点时发现,首要的就是把Runnable、Callable、Executor、Future等的关系搞明白,遂有了下述小测试程序,通过这个例子上述三者的关系就一目了然了。
在java5以后,一个可以调度执行的线程单元可以有三种方式定义:
Thread、Runnable、Callable,其中Runnable实现的是void run()方法,Callable实现的是 V call()方法,并且可以返回执行结果,其中Runnable可以提交给Thread来包装下,直接启动一个线程来执行,而Callable则一般都是提交给ExecuteService来执行。
简单来说,Executor就是Runnable和Callable的调度容器,Future就是对于具体的调度任务的执行结果进行查看,最为关键的是Future可以检查对应的任务是否已经完成,也可以阻塞在get方法上一直等待任务返回结果。Runnable和Callable的差别就是Runnable是没有结果可以返回的,就算是通过Future也看不到任务调度的结果的。
执行结果如下:
FutureTask则是一个RunnableFuture<V>,即实现了Runnbale又实现了Futrue<V>这两个接口,另外它还可以包装Runnable和Callable<V>,所以一般来讲是一个符合体了,它可以通过Thread包装来直接执行,也可以提交给ExecuteService来执行,并且还可以通过v get()返回执行结果,在线程体没有执行完成的时候,主线程一直阻塞等待,执行完则直接返回结果。
执行结果如下:
0 0
- Runnable、Callable、Executor、Future、FutureTask关系解读
- Runnable、Callable、Executor、Future、FutureTask关系解读
- Runnable、Callable、Executor、Future、FutureTask关系解读
- Runnable、Callable、Executor、Future、FutureTask关系解读
- Runnable、Callable、Executor、Future、FutureTask关系解读
- Runnable、Callable、Executor、Future、FutureTask关系解读
- Runnable、Callable、Executor、Future、FutureTask关系解读
- Runnable、Callable、Executor、Future、FutureTask关系解读
- java多线程Runnable、Callable、Executor、Future、FutureTask关系解读
- Runnable、Callable、Executor、Future、FutureTask
- Android线程池(九) Runnable、Callable、Executor、Future、FutureTask关系解读
- Future/FutureTask & Callable/Runnable & Executor/ExecutorService/Executors
- Runnable、Callable、Future、FutureTask
- Runnable、Callable、Future、FutureTask
- Runnable、Callable、Executor、Future
- Runnable/Thread/Callable/Future/FutureTask
- Runnable、Callable、Future 和 FutureTask
- Runnable,Callable,Future,RunnableFuture,FutureTask,ExecutorService的关系
- solr入门之使用Solr完成拼写纠错的实现思路
- 给radioButtonList 增加间距
- Kafka API for Python
- 金融和经济数据应用
- iOS-导航头像缩放,支持点击回调
- Runnable、Callable、Executor、Future、FutureTask关系解读
- |Tyvj|NOIP2000|动态规划|P1047 乘积最大
- FLV文件格式官方规范详解
- 用gdb调试动态链接库
- jqgrid实现多行数据弹出框添加修改查询操作
- 51 nod 1376 最长递增子序列的数量(二维偏序cdq)
- 负载均衡的分类
- Android网络请求
- Android进阶之路-标题与Fragment的简单演奏