java多线程之Future和FutureTask使用实例

qqstrategy55120 15 0 pdf 2021-05-08 05:05:44

Executor框架使用Runnable 作为其基本的任务表示形式。对于这种任务,Callable是一个更好的抽象,他能返回一个值,并可能抛出一个异常。Future表示一个任务的周期,并提供了相应的方法来判断是否已经完成或者取消,以及获取任务的结果和取消任务。ExecutorService中的submit方法接受一个Runnable或者Callable,然后返回一个Future来获得任务的执行结果或者取消任务。能够想到的办法是调用函数后,立即返回,然后继续执行,等需要用数据的时候,再取或者等待这个数据。具体实现有两种方式,一个是用Future,另一个是回调。也就是说在执行getDataFromRemoteByFuture的时候,就已经启动了对远程计算结果的获取,同时自己的线程还继续执行不阻塞。把任务加入线程池之后,理解返回Future对象。

java多线程之Future和FutureTask使用实例

java多线程之Future和FutureTask使用实例

java多线程之Future和FutureTask使用实例

java多线程之Future和FutureTask使用实例

java多线程之Future和FutureTask使用实例

java多线程之Future和FutureTask使用实例

java多线程之Future和FutureTask使用实例

java多线程之Future和FutureTask使用实例

java多线程之Future和FutureTask使用实例

java多线程之Future和FutureTask使用实例

用户评论
请输入评论内容
评分:
暂无评论