响应式编程Reactor优化Callback回调地狱

这篇具有很好参考价值的文章主要介绍了响应式编程Reactor优化Callback回调地狱。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1. Reactor是什么

  • Reactor 是一个基于Reactive Streams规范的响应式编程框架。它提供了一组用于构建异步、事件驱动、响应式应用程序的工具和库。Reactor 的核心是 Flux(表示一个包含零到多个元素的异步序列)和 Mono表示一个包含零或一个元素的异步序列)。
  • Reactor 通过提供响应式的操作符,如mapfilterflatMap等,使得开发者能够方便地进行数据流的转换和处理。

2. Reactor、Callback、CompletableFuture三种形式异步编码对比

  • 编码简洁程度Reactor最优
  • Reactor线程利用率最高(因实现了Reactive Streams规范,拥有背压+事件驱动特性,此处暂不展开)

代码如下:

pom依赖

<dependencyManagement>
   <dependencies>
       <dependency>
           <groupId>io.projectreactor</groupId>
           <artifactId>reactor-bom</artifactId>
           <version>2023.0.0</version>
           <type>pom</type>
           <scope>import</scope>
       </dependency>
   </dependencies>
</dependencyManagement>

<dependencies>
   <dependency>
       <groupId>io.projectreactor</groupId>
       <artifactId>reactor-core</artifactId>
   </dependency>
</dependencies>

Callback回调地狱

interface FirstCallback {
    void onCompleteFirst(String result);

    void onErrorFirst(Exception e);
}

interface SecondCallback {
    void onCompleteSecond(String result);

    void onErrorSecond(Exception e);
}

interface ThirdCallback {
    void onCompleteThird(String result);

    void onErrorThird(Exception e);
}

class AsyncOperations {
    static void firstOperation(FirstCallback firstCallback) {
        new Thread(() -> {
            try {
                // 模拟异步操作
                Thread.sleep(2000);
                // 操作完成后调用回调函数
                firstCallback.onCompleteFirst("First operation completed");
            } catch (Exception e) {
                // 发生异常时调用错误回调
                firstCallback.onErrorFirst(e);
            }
        }).start();
    }

    static void secondOperation(String input, SecondCallback secondCallback) {
        new Thread(() -> {
            try {
                // 模拟异步操作
                Thread.sleep(2000);
                // 操作完成后调用回调函数
                secondCallback.onCompleteSecond("Second operation completed with input: " + input);
            } catch (Exception e) {
                // 发生异常时调用错误回调
                secondCallback.onErrorSecond(e);
            }
        }).start();
    }

    static void thirdOperation(String input, ThirdCallback thirdCallback) {
        new Thread(() -> {
            try {
                // 模拟异步操作
                Thread.sleep(2000);
                // 操作完成后调用回调函数
                thirdCallback.onCompleteThird("Third operation completed with input: " + input);
            } catch (Exception e) {
                // 发生异常时调用错误回调
                thirdCallback.onErrorThird(e);
            }
        }).start();
    }
}

public class CallbackHellExample {
    public static void main(String[] args) {
        AsyncOperations.firstOperation(new FirstCallback() {
            @Override
            public void onCompleteFirst(String result) {
                System.out.println("First Callback: " + result);

                // 第一次操作完成后调用第二次操作
                AsyncOperations.secondOperation(result, new SecondCallback() {
                    @Override
                    public void onCompleteSecond(String result) {
                        System.out.println("Second Callback: " + result);

                        // 第二次操作完成后调用第三次操作
                        AsyncOperations.thirdOperation(result, new ThirdCallback() {
                            @Override
                            public void onCompleteThird(String result) {
                                System.out.println("Third Callback: " + result);
                            }

                            @Override
                            public void onErrorThird(Exception e) {
                                System.out.println("Error in Third Callback: " + e.getMessage());
                            }
                        });
                    }

                    @Override
                    public void onErrorSecond(Exception e) {
                        System.out.println("Error in Second Callback: " + e.getMessage());
                    }
                });
            }

            @Override
            public void onErrorFirst(Exception e) {
                System.out.println("Error in First Callback: " + e.getMessage());
            }
        });

        // 主线程继续执行其他操作
        System.out.println("Main thread continues...");
    }
}

CompletableFuture优化Callback回调地狱

public class CompletableFutureExample {
    public static void main(String[] args) {
        CompletableFuture<String> firstOperation = CompletableFuture.supplyAsync(() -> {
            try {
                // 模拟异步操作
                Thread.sleep(2000);
                return "First operation completed";
            } catch (InterruptedException e) {
                throw new RuntimeException(e);
            }
        });

        CompletableFuture<String> secondOperation = firstOperation.thenApplyAsync(result -> {
            System.out.println("First CompletableFuture: " + result);
            try {
                // 模拟异步操作
                Thread.sleep(2000);
                return "Second operation completed with input: " + result;
            } catch (InterruptedException e) {
                throw new RuntimeException(e);
            }
        });

        CompletableFuture<String> thirdOperation = secondOperation.thenApplyAsync(result -> {
            System.out.println("Second CompletableFuture: " + result);
            try {
                // 模拟异步操作
                Thread.sleep(2000);
                return "Third operation completed with input: " + result;
            } catch (InterruptedException e) {
                throw new RuntimeException(e);
            }
        });

        thirdOperation.whenComplete((result, throwable) -> {
            if (throwable == null) {
                System.out.println("Third CompletableFuture: " + result);
            } else {
                System.out.println("Error in CompletableFuture: " + throwable.getMessage());
            }
        });

        // 主线程继续执行其他操作
        System.out.println("Main thread continues...");

        // 等待所有操作完成
        CompletableFuture.allOf(firstOperation, secondOperation, thirdOperation).join();
    }
}

Reactor优化Callback回调地狱

public class ReactorOptimizedExample {
    public static void main(String[] args) {
        Mono.fromCallable(() -> {
                    // 模拟异步操作
                    Thread.sleep(2000);
                    return "First operation completed";
                })
                .subscribeOn(Schedulers.boundedElastic())
                .flatMap(result -> {
                    System.out.println("First Reactor: " + result);
                    return Mono.fromCallable(() -> {
                        // 模拟异步操作
                        Thread.sleep(2000);
                        return "Second operation completed with input: " + result;
                    }).subscribeOn(Schedulers.boundedElastic());
                })
                .flatMap(result -> {
                    System.out.println("Second Reactor: " + result);
                    return Mono.fromCallable(() -> {
                        // 模拟异步操作
                        Thread.sleep(2000);
                        return "Third operation completed with input: " + result;
                    }).subscribeOn(Schedulers.boundedElastic());
                })
                .doOnSuccess(result -> System.out.println("Third Reactor: " + result))
                .doOnError(error -> System.out.println("Error in Reactor: " + error.getMessage()))
                .block(); // 阻塞等待操作完成

        // 主线程继续执行其他操作
        System.out.println("Main thread continues...");
    }
}

学习打卡:Java学习笔记-day06-响应式编程Reactor优化Callback回调地狱文章来源地址https://www.toymoban.com/news/detail-788420.html

到了这里,关于响应式编程Reactor优化Callback回调地狱的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 响应式编程Reactor API大全(中)

    Reactor 是一个基于响应式编程的库,主要用于构建异步和事件驱动的应用程序。Reactor 提供了丰富的 API,包括创建、转换、过滤、组合等操作符,用于处理异步数据流。以下是一些 Reactor 的主要 API 示例: pom依赖 22. 使用 Reactor 的 elapsed 方法进行时间测量 elapsed 方法可以用于测

    2024年02月01日
    浏览(72)
  • 响应式编程Reactor API大全(上)

    Reactor 是一个基于响应式编程的库,主要用于构建异步和事件驱动的应用程序。Reactor 提供了丰富的 API,包括创建、转换、过滤、组合等操作符,用于处理异步数据流。以下是一些 Reactor 的主要 API 示例: pom依赖 1. 创建 Mono 和 Flux Mono : 用于表示包含零个或一个元素的异步序列

    2024年01月25日
    浏览(45)
  • 回调地狱Axios

    ## 解决回调地狱:Promise 和 Axios 在现代的前端开发中,处理异步操作和网络请求是非常常见的任务。使用 Promise 和 Axios 可以更轻松地管理异步代码和发送网络请求。 ### Promise Promise 是一种用于处理异步操作的对象,它有三种状态:pending(进行中)、fulfilled(已成功)、reje

    2024年02月04日
    浏览(44)
  • 解决微信小程序回调地狱问题

    一、背景     小程序开发经常遇到根据网络请求结果,然后继续 处理下一步业务操作,代码如下: 这段代特点:层层嵌套,逻辑负责可读性低,不易维护。解决方案使用 new Promise((resolve, reject) = {})可使用异步顺序执行来解决。 二、代码示例 第一个请求函数代码示例 第

    2024年02月09日
    浏览(52)
  • 记录--没有await,如何处理“回调地狱”

    不要嵌套使用函数。给每个函数命名并把他们放在你代码的顶层 利用函数提升。先使用后声明。 处理每一个异常 编写可以复用的函数,并把他们封装成一个模块 异步Javascript代码,或者说使用callback的Javascript代码,很难符合我们的直观理解。很多代码最终会写成这样: 看到

    2024年02月04日
    浏览(39)
  • Python异步编程高并发执行爬虫采集,用回调函数解析响应

    异步技术是Python编程中对提升性能非常重要的一项技术。在实际应用,经常面临对外发送网络请求,调用外部接口,或者不断更新数据库或文件等操作。 这这些操作,通常90%以上时间是在等待,如通过REST, gRPC向服务器发送请求,通常可能等待几十毫秒至几秒,甚至更长。如

    2024年02月08日
    浏览(52)
  • JS回调函数(callback)

    在使用Jquery的时候,用到Callback(),回调函数的概念。并且不少。javascript 好比:html 回调函数你们都会用,只是Jquery封装了以后,不能让你们明白回调函数的真正使用。 JS Api 里这样解释:A callback is a function that is passed as an argument to another function and is executed after its parent funct

    2024年02月09日
    浏览(38)
  • 【Promise】一文带你了解promise并解决回调地狱

    为什么需要promise 需求 通过ajax请求id,再根据id请求用户名,再根据用户名获取email 回调地狱 在回调函数中嵌套回调 在上述代码中通过不断请求数据,代码逐级向外递归,形成了回调地狱。 使用promise就可以完美解决,并且让我们的代码更加美观。 Promise是一个构造函数,通过n

    2024年02月21日
    浏览(41)
  • vue 回调函数(callback)的用法

    一、介绍: 1、前提:在 js 中,函数也是对象,可以赋值给变量,可以作为参数放在函数的参数列表中,如: 2、概念: callback 是一种特殊的函数,这个函数被作为参数传给另一个函数去调用,这样的函数就是回调函数。回调,顾名思义,回头再调。回调与同步、异步并没有

    2023年04月16日
    浏览(39)
  • Callback回调函数介绍(C语言)

    目录 1. 回调函数的定义 2. 为什么要用回调函数 3. 怎么用回调函数 3.1 怎么使用没有参数的回调函数 3.2 怎么使用带参数的回调函数 最近在工作中经常用到回调函数callback,总结一下。 先来看看维基百科对callback的解释:In computer programming, a callback is any executable code that is pass

    2024年02月02日
    浏览(54)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包