FutureTask 是一个支持取消的异步处理器,一般在线程池中用于异步接受callable返回值。
主要实现分三部分:
封装 Callable,然后放到线程池中去异步执行->run。
获取结果-> get。
取消任务-> cancel。
接下来主要学习下该模型如何实现。
举例说明FutureTask在线程池中的应用
// 第一步,定义线程池,
ExecutorService executor = new ThreadPoolExecutor(
minPoolSize,
maxPollSize,
keepAliveTime,
TimeUnit.SECONDS,
new SynchronousQueue<>());
// 第二步,放到线程池中执行,返回FutureTask
FutureTask task = executor.submit(callable);
// 第三步,获取返回值
T data = task.get();
学习FutureTask实现
类属性
//以下是FutureTask的各种状态
private volatile int state;
private static final int NEW = 0;
private static final int COMPLETING = 1;
private static final int NORMAL = 2;
private static final int EXCEPTIONAL = 3;
private static final int CANCELLED = 4;
private static final int INTERRUPTING = 5;
private static final int INTERRUPTED = 6;
private Callable<V> callable; //执行的任务
private Object outcome; //存储结果或者异常
private volatile Thread runner;//执行callable的线程
private volatile WaitNode waiters; //调用get方法等待获取结果的线程栈
其中各种状态存在 最终状态 status>COMPLETING
1)NEW -> COMPLETING -> NORMAL(有正常结果)
2) NEW -> COMPLETING -> EXCEPTIONAL(结果为异常)
3) NEW -> CANCELLED(无结果)
4) NEW -> INTERRUPTING -> INTERRUPTED(无结果)
类方法
从上面举例说明开始分析。
run()方法
FutureTask 继承 Runnable,ExecutorService submit 把提交的任务封装成 FutureTask 然后放到线程池 ThreadPoolExecutor 的 execute 执行。
public void run() {
//如果不是初始状态或者cas设置运行线程是当前线程不成功,直接返回
if (state != NEW ||
!U