实战场景
最近我们项目要把两个API接口合并成一个接口, 但是为了平滑迁移以及减少对代码的修改造成的影响, 所以新创建一个Request和Service, 新Service通过建立两个FutureTask并行去取结果,然后进行结果合并.
需要注意的是, 我们生产环境的openresty是5秒超时, 所以第二个请求需要设置超时时间,指定时间内取不到结果则取消该Task, 把第一个结果返回.
what is FutureTask
Future 就是对于具体的Runnable或者Callable任务的执行结果进行取消、查询是否完成、获取结果。必要时可以通过get方法获取执行结果,该方法会阻塞直到任务返回结果。
FutureTask是Future接口的一个唯一实现类。
FutureTask implements RunnableFuture extends Runnable, Future
FutureTask实现了RunableFuture接口,同时RunableFuture又继承Future,Runable接口,也就是说FutureTask具备Runbale的run方法执行异步任务,也可以像Future一样能够控制任务的执行
FutureTask的常用API
- cancel()
cancel方法用来取消任务,如果取消任务成功则返回true,如果取消任务失败则返回false。参数mayInterruptIfRunning表示是否允许取消正在执行却没有执行完毕的任务,如果设置true,则表示可以取消正在执行过程中的任务。如果任务已经完成,则无论mayInterruptIfRunning为true还是false,此方法肯定返回false,即如果取消已经完成的任务会返回false;如果任务正在执行,若mayInterruptIfRunning设置为true,则返回true,若mayInterruptIfRunning设置为false,则返回false;如果任务还没有执行,则无论mayInterruptIfRunning为true还是false,肯定返回true。
- isCancelled()
isCancelled方法表示任务是否被取消成功,如果在任务正常完成前被取消成功,则返回 true。
- isDone()
isDone方法表示任务是否已经完成,若任务完成,则返回true;
-
get() get()方法用来获取执行结果,这个方法会产生阻塞,会一直等到任务执行完毕才返回;
-
get(long timeout, TimeUnit unit)
get(long timeout, TimeUnit unit)用来获取执行结果,如果在指定时间内,还没获取到结果,就抛出异常TimeoutException。