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

流的有状态和无状态方法

冯阳成
2023-03-14

在接口流中:

中间操作可分为有状态和无状态。它们影响并行流的结果。

只有两个终端操作是非确定性方法:findAny()和forEach(Consumer)。它们影响并行流的结果。

如果中间无状态操作html" target="_blank">执行惰性操作,它们可能会产生副作用。这会影响并行Stream的结果。

中间操作可分为以下几类:

有状态

  • 不同的()
  • 排序()
  • 极限(长l)
  • 跳过(长l)

无国籍

  • 地图(功能f)

以下是我的两个问题:

>

  • 无状态中间方法

    • 如果我将并行流上的无状态中间方法称为非确定性的foreach(),我将获得顺序流的相同结果,但顺序不同。
    • 如果我调用并行流上的无状态中间方法非确定性findany(),我将获得一个不可预测的结果。
    • 如果我调用并行流上的无状态中间方法进行正常的终端操作,我将获得相同的顺序流结果。
    • 如果我在并行流上调用无状态中间方法,正常终端操作有副作用,我会得到一个不可预测的结果。

    有状态中间方法

    • 如果我调用有状态的中间方法nondeterministic forEach(),我将获得顺序流的相同结果,但顺序不同
    • 如果我调用有状态的中间方法nondeterministic findAny(),我将得到一个不可预测的结果
    • 如果我调用有状态的中间方法进行正常的终端操作,我将获得与序列流相同的结果

    这些规则正确吗?

    非常感谢!

    A.

  • 共有1个答案

    吴高远
    2023-03-14

    我想条件1和2都是真的。我想添加一些操作。

    reduce也是有状态操作的一部分。

    forEach是无状态操作的一部分。

    请注意,无状态操作如果产生副作用,可能会成为有状态操作。

    第三种说法并不完全正确。如果一个流是有序的,并且我们并行处理它,那么当与无状态操作一起使用时,该流将保持有序。这就是为什么我们需要在流上调用方法unordered(),使其无序并提高效率。

     类似资料:
    • 问题内容: 我正在阅读Java EE 6教程,试图理解无状态会话bean和有状态会话bean之间的区别。如果无状态会话bean在方法调用之间没有保持其状态,为什么我的程序按原样运行? 客户端 我原本希望getNumber每次都返回0,但它返回1,并且在浏览器中重新加载servlet会使它更多。问题在于我对无状态会话Bean如何工作的理解,而与库或应用程序服务器无关。有人可以给我一个无状态会话bea

    • 我已经开始学习ReactJS,有一个关于无状态和有状态组件的问题。一般来说,我遵循组件和容器的分离,如下所示。有状态函数在组件文件夹中,其他逻辑操作在容器文件夹下。文件夹结构 让我们思考材料UI下拉列表。 为了打开和关闭下拉菜单和方法更改打开状态,这意味着它是有状态组件。但没有其他变化(省略年龄设置)。它似乎是可重用的组件,但包括状态与非常简单的操作,如打开和关闭。我应该放入哪个文件夹?容器还是组

    • 帮助用户快速部署无状态的应用。 无状态应用即Deployment,Deployment的详细介绍内容,请参考kubernets官方文档-Deployments。 Pod是Kubernetes的最小编排单位,无状态deployment应用即通过声明pod模板等信息编排部署无状态应用,适用于pod完全一样、没有顺序、无所谓运行在哪台主机的应用。 入口:在云管平台单击左上角导航菜单,在弹出的左侧菜单栏中

    • 问题内容: 根据OCP的书,必须避免有状态操作,否则称为有状态lambda表达式。本书中提供的定义是“有状态的lambda表达式,其结果取决于在管道执行期间可能更改的任何状态”。 它们提供了一个示例,其中使用并行流使用函数将固定的数字集合添加到同步的ArrayList 。 arraylist中的顺序是完全随机的,这应该使人看到有状态的lambda表达式在运行时会产生不可预测的结果。因此,强烈建议在

    • 问题内容: 我试图了解React的有状态和无状态组件之间的确切区别。好的,无状态组件只会做某事,但是什么也不会记住,而有状态组件可能会做同样的事情,但是它们会记住其中的内容。那是理论。 但是现在,在检查如何使用代码显示此内容时,我有点麻烦了。以下两个示例对吗?唯一的区别确实是函数的定义。 无状态组件的示例: 有状态组件的示例: 问题答案: 是的,那是有区别的。除了有 状态 组件,您还可以使用以下方

    • 需要一些帮助!!我对Drools中的有状态和无状态会话没有清晰的理解。我正在努力理解这一点,所以尝试了一个例子。 我在drools6.5版本上使用有状态和无状态会话测试了下面的drl,在这两种情况下都得到了相同的输出。根据我对无状态会话的理解,它应该只执行第一条规则,当应用程序对象在第一条规则中被修改时,第二条规则不应该被激活(“有效期”)。附加源代码。感谢您在这方面的帮助。