package com.nanjing.gulimall.zhouyimo.test;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;
/**
* @author zhou
*/
public class FutureApiDemo {
public static void main(String[] args) throws ExecutionException, InterruptedException, TimeoutException {
FutureTask<String> futureTask = new FutureTask<>(() -> {
System.out.println(Thread.currentThread().getName() + "--------come in");
try {
TimeUnit.SECONDS.sleep(5);
} catch (InterruptedException e) {
e.printStackTrace();
}
return "task over";
});
Thread t1 = new Thread(futureTask, "t1");
t1.start();
System.out.println(Thread.currentThread().getName() + " ------忙其他任务");
//轮询
while (true) {
if(futureTask.isDone()){
System.out.println(futureTask.get());
break;
}else{
//暂停毫秒
TimeUnit.MILLISECONDS.sleep(500);
System.out.println("正在处理中,不要催了,越催越慢");
}
}
}
}
main ------忙其他任务
t1--------come in
正在处理中,不要催了,越催越慢
正在处理中,不要催了,越催越慢
正在处理中,不要催了,越催越慢
正在处理中,不要催了,越催越慢
正在处理中,不要催了,越催越慢
正在处理中,不要催了,越催越慢
正在处理中,不要催了,越催越慢
正在处理中,不要催了,越催越慢
正在处理中,不要催了,越催越慢
正在处理中,不要催了,越催越慢
task over
轮询的方式会耗费无谓的cpu资源,而且也不见得能及时地得到计算结果。
如果想要异步获取结果,通常都会以轮询的方式去获取结果,尽量不要阻塞。
说明isDone()轮询判断的方式比get()要好些。
结论:Future对于结果的获取不是很友好,只能通过阻塞或轮询的方式得到任务的结果。
Future异步优化思路