ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

java – Reactor compose vs flatMap

2019-07-24 11:28:21  阅读:191  来源: 互联网

标签:project-reactor java spring


我继续玩Reactor,现在我看到compose运算符的行为与flatMap完全一样,我想知道是否有任何我不理解的差异.

    @Test
public void compose() throws InterruptedException {
    Scheduler mainThread = Schedulers.single();
    Flux.just(("old element"))
            .compose(element ->
                    Flux.just("new element in new thread")
                            .subscribeOn(mainThread)
                            .doOnNext(value -> System.out.println("Thread:" + Thread.currentThread().getName())))
            .doOnNext(value -> System.out.println("Thread:" + Thread.currentThread().getName()))
            .subscribe(System.out::println);
    Thread.sleep(1000);
}

@Test
public void flatMapVsCompose() throws InterruptedException {
    Scheduler mainThread = Schedulers.single();
    Flux.just(("old element"))
            .flatMap(element ->
                    Flux.just("new element in new thread")
                            .subscribeOn(mainThread)
                            .doOnNext(value -> System.out.println("Thread:" + Thread.currentThread().getName())))
            .doOnNext(value -> System.out.println("Thread:" + Thread.currentThread().getName()))
            .subscribe(System.out::println);
    Thread.sleep(1000);
}

这两个示例表现并返回相同的结果.

问候.

解决方法:

An excellent explanation by Dan Lew

不同之处在于compose()是一个更高级别的抽象:它在整个流上运行,而不是单独发出的项目.更具体的说法:

> compose()是获得原始Observable< T>的唯一方法.从溪流.因此,影响整个流的运算符(如subscribeOn()和observeOn())需要使用compose().

相反,如果将subscribeOn()/ observeOn()放在flatMap()中,它只会影响您在flatMap()中创建的Observable,而不会影响流的其余部分.
> compose()在您创建Observable流时立即执行,就像您已编写内联运算符一样. flatMap()在每次调用onNext()时都会执行.换句话说,flatMap()转换每个项目,而compose()转换整个流.
> flatMap()的效率必然较低,因为每次调用onNext()时都必须创建一个新的Observable. compose()按原样对流进行操作.如果要使用可重用代码替换某些运算符,请使用compose(). flatMap()有很多用途,但这不是其中之一.

标签:project-reactor,java,spring
来源: https://codeday.me/bug/20190724/1521956.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有