电商项目——商城业务-异步——第七章——中篇

本文深入探讨电商项目中的异步处理,重点关注Java中的CompletableFuture,包括如何启动异步任务、实现线程池详解、利用CompletableFuture进行任务组合与线程串行化,以及异常处理。通过实例代码展示了如何在分布式环境中有效编排异步任务。
摘要由CSDN通过智能技术生成

电商项目——全文检索-ElasticSearch——第一章——中篇
电商项目——商城业务-商品上架——第二章——中篇
电商项目——商城业务-首页——第三章——中篇
电商项目——性能压测——第四章——中篇
电商项目——缓存——第五章——中篇
电商项目——商城业务-检索服务——第六章——中篇
电商项目——商城业务-异步——第七章——中篇
电商项目——商品详情——第八章——中篇
电商项目——认证服务——第九章——中篇
电商项目——购物车——第十章——中篇
电商项目——消息队列——第十一章——中篇
电商项目——订单服务——第十二章——中篇
电商项目——分布式事务——第十三章——中篇

1:异步复习

异步复习

2:线程池详解

线程池详解

3:CompletableFuture

  • 在分布式架构中,我们还有一个需要解决的复杂任务场景,比如A,B,C三个异步任务进行运行,C必须等待A运行完的返回结果后才可以运行,B又不用等A,C我们可以直接异步运行,我们要编排好他们的业务进行异步调用又是一个复杂的过程,我们举一个例子,如下就是在分布式架构中搭建电商项目遇到的一个问题
    在这里插入图片描述

我们必须要先完成1以后,查询完sku,才知道它对应的spu,知道了spu以后,我们才可以完成4,5,6(4,5,6可以并发执行),我们这就要使用CompletableFuture异步编排来解决

我们就可以使用CompletableFuture来解决这个问题

3.1 启动异步任务

在这里插入图片描述
代码测试

//我们自己创建的一个线程池
    public static ExecutorService executor= Executors.newFixedThreadPool(10);

    public static void main(String[] args) throws ExecutionException, InterruptedException {
   

        System.out.println("main。。。。start..");

        CompletableFuture.runAsync(()->{
   
            System.out.println("当前线程:"+Thread.currentThread().getId());
            int i=10/2;
            System.out.println("运行结果:"+i);
        },executor);

        CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> {
   
            System.out.println("当前线程:" + Thread.currentThread().getId());
            int i = 10 / 2;
            System.out.println("运行结果:" + i);
            return i;
        }, executor);

        System.out.println("supplyAsync运行的结果:"+future.get());

        System.out.println("main。。。。end..");

    }

在这里插入图片描述

3.2 完成回调与异常感知

在这里插入图片描述
代码测试:下面的代码测试涉及到java8新特性函数式接口
Java8新特性——核心——Lambda和Stream
在这里插入图片描述
Java8 引入了函数式接口,并在java.util.function 包内预定义了常用函数式接口,下表罗列了一些常用的函数式接口:
在这里插入图片描述

  //我们自己创建的一个线程池
    public static ExecutorService executor= Executors.newFixedThreadPool(10);

    public static void main(String[] args) throws ExecutionException, InterruptedException {
   

        System.out.println("main。。。。start..");

        CompletableFuture<Integer> future = CompletableFuture.supplyAsync(() -> {
   
            System.out.println("当前线程:" + Thread.currentThread().getId());
                        /**
             * @FunctionalInterface
            public interface Supplier<T> {
            
             * @return a result
             
            T get();
        }
             */
            int i = 10 / 0;
            System.out.println("运行结果:" + i);
            return i;
        }, executor).whenComplete((res,exc)->{
   

            /**
             * @FunctionalInterface
            public interface BiConsumer<T, U> {

            void accept(T t, U u);
             */
            //虽然可以得到异常信息,但是没法返回修改数据
            System.out.println("异步任务成功完成:结果是:"+res+";异常是" + exc);
        }).exceptionally(throwable -> {
   
            //可以感知异常,同时返回默认值
                     /**
             * @FunctionalInterface
            public interface Function<T, R> {
            
            R apply(T t);
             */
            return 10;
        });
        System.out.println("exceptionally运行的结果:"+future.get());

        System.out.println("main。。。。end..");

在这里插入图片描述

3.3 handle最终处理

在这里插入图片描述
代码测试:下面的代码测试涉及到java8新特性函数式接口
Java8新特性——核心——Lambda和Stream
在这里插入图片描述
Java8 引入了函数式接口,并在java.util.function 包内预定义了常用函数式接口,下表罗列了一些常用的函数式接口:
在这里插入图片描述

 //我们自己创建的一个线程池
    public static ExecutorService executor
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值