JUC并发编程 CompletableFuture 常用方法(二)

1 获得结果和触发计算

1.1 获取结果

  • public T get()
    
  • public T get(long timeout,TimeUnit unit)
    
  • public T join() --->和get一样的作用,只是不需要抛出异常
    
  • public T getNow(T valuelfAbsent) --->计算完成就返回正常值,否则返回备胎值(传入的参数),立即获取结果不阻塞
    

1.2 主动触发计算

  • public boolean complete(T value) ---->是否打断线程方法立即返回括号值
    

1.3 案例实操

前面文章已经介绍过get() 和 get(long timeout,TimeUnit unit) 使用方法了,这里就直接略过。

1.3.1 join()

和get一样的作用,只是不需要抛出异常

    public static void main(String[] args) {
        
        CompletableFuture<String> completableFuture = CompletableFuture.supplyAsync(() -> {
            
            try {
                TimeUnit.SECONDS.sleep(1);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            return "abc";
        });
        System.out.println(completableFuture.get());

        System.out.println(completableFuture.join());

    }

1.3.2 getNow(T valuelfAbsent)

    public static void main(String[] args) {
        
        CompletableFuture<String> completableFuture = CompletableFuture.supplyAsync(() -> {
            
            try {
                TimeUnit.SECONDS.sleep(3);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            return "abc";
        });

        
        try {
            TimeUnit.SECONDS.sleep(2);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        /**
         * 如果CompletableFuture线程没有计算的时间 小于 主线程  那么 结果是 XXXX
         * 反之 则是 CompletableFuture 线程的计算结果
         */
        System.out.println(completableFuture.getNow("xxxx"));
 

        
        
    }

1.3.3 public boolean complete(T value)

是否打断线程方法立即返回括号值

 public static void main(String[] args) {
        
        CompletableFuture<String> completableFuture = CompletableFuture.supplyAsync(() -> {
            
            try {
                TimeUnit.SECONDS.sleep(3);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            return "abc";
        });


        try {
            TimeUnit.SECONDS.sleep(2);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println(completableFuture.complete("completevalue")+"\t"+completableFuture.join());
        
        
    }

2 对计算结果进行处理

2.1 方法介绍

  • thenApply --->计算结果存在依赖关系,这两个线程串行化---->由于存在依赖关系(当前步错,不走下一步),当前步骤有异常的话就叫停
  • handle --->计算结果存在依赖关系,这两个线程串行化---->有异常也可以往下走一步

2.2 案例实操

2.2.1 thenApply

计算结果存在依赖关系,这两个线程串行化---->由于存在依赖关系(当前步错,不走下一步),当前步骤有异常的话就叫停

    private static void thenApplyTest(){
        
//        ExecutorService threadPool = Executors.newFixedThreadPool(3);
        
        CompletableFuture.supplyAsync(()->{
            System.out.println("111"+Thread.currentThread().getName());

            try {
                TimeUnit.SECONDS.sleep(1);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            return 1;
        }).thenApply(f->{
//            int i =10/0;
            System.out.println("222");
            return f + 2;
        }).thenApply(f->{
            System.out.println("333");
            return f + 3;
        }).whenComplete((v,e)->{
            if(e == null){
                System.out.println("-------计算结果:"+v);
            }
        }).exceptionally(e->{
            e.printStackTrace();
            System.out.println(e.getMessage());
            return null;
        });

        System.out.println(Thread.currentThread().getName()+"-------主线程先去忙其他任务");
    
    }

发现上面线程
(未完待续)

posted @ 2024-01-14 15:42  KwFruit  阅读(27)  评论(0编辑  收藏  举报