CompletableFuture-futureTask.isDone()轮询判断耗费CPU

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 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异步优化思路

CompletableFuture-futureTask.isDone()轮询判断耗费CPU_第1张图片

 

你可能感兴趣的:(JUC并发编程与源码分析,java,开发语言)