当前位置: 首页 > 知识库问答 >
问题:

RxJava API和Java9 Flow API之间的区别

狄易安
2023-03-14

在Java最近几个主要版本的每一次迭代中,似乎都有管理并发任务的新方法。

在Java9中,我们有Flow API,它类似于RxJava的Flowable API,但在Java9中,它有一组简单得多的类和接口。

Java 9

具有类似流API的类的完整包,即io.reactivex.flowablesio.reactivex.subscribersio.reactivex.processorsio.reactivex.observables,它们似乎做了类似的事情。

这两个库的主要区别是什么?为什么有人会使用Java9Flow库而不是更多样化的RxJava库,或者反之亦然?

共有1个答案

施喜
2023-03-14

这两个库的主要区别是什么?

Java9Flow API不是一个独立的库,而是Java Standard Edition库的一个组件,由采用2015年初建立的Reactive Streams规范的4个接口组成。理论上,它的包含可以支持in-JDK中的特定用法,例如孵化的HttpClient,可能是计划的parts中的异步数据库连接,当然还有SubmissionPublisher

RxJava是一个Java库,它使用ReactiveX风格的API设计,在reactive(push)数据流上提供丰富的运算符集。版本2通过flowable和各种xxxprocessor实现了Reactive Streams API,该API允许其他兼容库使用flowable实例,进而可以将任何发布者包装成flowable来使用这些实例,并用它们组成丰富的操作符集。

因此,Reactive Streams API是最小的接口规范,RXJava2是它的一个实现,另外RxJava声明了一大组额外的方法,以形成自己丰富而流畅的API。

RXJava1启发了Reactive Streams规范,但不能利用它(必须保持兼容)。RXJava2是一个完整的重写版本和一个独立的主版本,它可以接受和使用Reactive Streams规范(由于Rsc项目,甚至可以在内部对其进行扩展),并且比Java9早一年发布。此外,决定v1和v2都支持Java6,从而支持大量的Android运行时。因此,它不能直接利用Java9提供的流API,而只能通过桥接。这种桥接器也被其它基于反应流的库所需要和/或提供。

RXJava3可能以Java9流API为目标,但这一点还没有决定,而且取决于后续Java版本带来的特性(即值类型),我们可能在一年左右的时间内不会有v3。

在此之前,有一个名为Reactive4JavaFlow的原型库,它实现了Flow API,并在其上提供了一个ReactiveX风格丰富的fluent API。

为什么有人会使用Java9Flow库而不是更多样化的RxJava库,或者反之亦然?

Flow API是互操作规范,而不是最终用户API。通常,您不会直接使用它,而是将流传递给它的各种实现。在讨论JEP 266时,作者没有发现任何现有库的API足够好,可以在Flow API中提供默认的内容(不像丰富的java.util.Stream)。因此,决定用户现在必须依赖第三方实现。

您必须等待现有的反应库通过它们自己的桥实现或将要实现的新库来支持Flow API。

在Flow API上提供丰富的运算符集只是库实现它的唯一原因。数据源供应商(即,反应型数据库驱动程序、网络库)可以开始通过流API实现他们自己的数据访问器,并依赖于丰富的库来包装这些访问器并为它们提供转换和协调,而不必强迫每个人实现各种这些操作符

因此,一个更好的问题是,您现在应该开始使用基于流API的互操作还是坚持使用反应流?

 类似资料:
  • 问题内容: 我错放了太多次了,我想我一直忘记,因为我不知道两者之间的区别,只是一个给了我我期望的价值,而另一个却没有。 为什么是这样? 问题答案: 是的简写形式(尽管请注意,该表达式只会被计算一次。) 是的,即指定一元的到。 例子:

  • 问题内容: 因此,我有一段简单的代码可以打印出整数1-10: 然后,如果仅在第3行上更改一个运算符,它将打印出无限数量的1整数(我知道为什么会这样做)。为什么在运行第二个程序时没有出现语法错误?如果赋值运算符后面跟着一个加法运算符,它不会调用语法错误吗? 问题答案: 与相同, 只是意味着。

  • 问题内容: 有人可以解释一下 和 我不知道“确切”的含义 问题答案: 在这个例子中,什么都没有。当您具有多个具有相似名称的路径时,该参数将起作用: 例如,假设我们有一个显示用户列表的组件。我们还有一个用于创建用户的组件。的网址应嵌套在下。因此,我们的设置可能如下所示: 现在,这里的问题是,当我们转到路由器时,将通过所有定义的路由,并返回它找到的第一个匹配项。因此,在这种情况下,它将首先找到路线,然

  • 问题内容: 我很好奇printStackTrace()和toString()之间的区别是什么。乍一看,他们 似乎 做的完全相同。 码: 问题答案: 不,有重要区别!使用toString,您只有异常的类型和错误消息。使用printStackTrace()可以获得异常的整个堆栈跟踪,这对于调试非常有帮助。 System.out.println(toString())的示例: printStackTra

  • 问题内容: 我看不到两种方式之间的任何区别,@ Qualifier 始终与 @Autowired一起使用 。 VS 有人能让我知道其中的区别吗?谢谢! 问题答案: 可以单独使用。如果单独使用,将按类型进行接线。因此,如果在容器中声明了多个相同类型的bean,而又不知道要注入哪个bean,就会出现问题。结果,通过指定Bean名称(按名称进行绑定),与一起使用来阐明要实际连接的Bean 也按名称接线。

  • 问题内容: System.getenv()和System.getProperty()有什么区别? 当我们使用Processbuilder运行任何命令时,我们可以设置环境变量,即: 如果在此方法之前使用System.setProperties()设置了一些属性,则该属性可用于由ProcessBuilder启动的此过程吗? 问题答案: 获取 环境变量 。获取Java属性。环境变量是在OS级别指定的。通

  • 问题内容: 和以下代码之间有什么区别: 和 他们是同义词吗?在某些情况下,一个比另一个更可取吗?使用这两种方法时该做什么和不该做什么? 问题答案: Class.forName()将始终使用调用者的ClassLoader,而ClassLoader.loadClass()可以指定其他ClassLoader。我相信Class.forName也会初始化加载的类,而ClassLoader.loadClass