【问题标题】:Java8 reducing a streamJava8减少流
【发布时间】:2014-05-30 23:10:16
【问题描述】:

我有以下方法:

static IntStream streamedDivisors(final int n) {
    return IntStream.range(2, n).parallel().filter(input -> n % input == 0);
}

static int streamedPhi(final int n) {
    return streamedDivisors(n).reduce(0, x -> x * x);
}

我在 streamedPhi 中遇到编译错误,表明我的 lambda 表达式中有不兼容的参数类型。有人可以帮我理解这一点吗?我实际上是在尝试取给定数字 n 的除数,并在我定义的某个函数上聚合一个数字(在这种情况下,对数字求平方)。

【问题讨论】:

  • 如果你想要平方和,这是一个映射一个减少(累加)。您已指定映射函数,但在错误的位置。而且你根本没有指定你的累积函数!您可能想要:streamedDivisors(n).map(x -> x*x).sum(),或除 sum 之外的其他一些缩减。
  • 是的,我后来想通了。得到你的纠正既是一种荣誉,也是一种尴尬:)说真的,我是@BrianGoetz 的忠实粉丝!您的书需要在工作日阅读

标签: java java-8 lambda java-stream


【解决方案1】:

您的编译问题是由于IntBinaryOperator#applyAsInt(int, int) 采用两个参数。你只是声明/提供一个。

正如 cmets 中所述,在查看 IntStream#reduce(int, IntBinaryOperator) 的 javadoc 之后,您实际上并没有应用有效的缩减。我不太清楚你的意思是什么并在我定义的某个函数上聚合一个数字但是Brian has some suggestions

【讨论】:

  • 这很奇怪。为什么它需要两个参数呢? var args 不是更合适吗?
  • @AmirAfghani 这是一个 binary 运算符。 2.
  • 我发现我遗漏了一些东西。我理解二进制的含义 - 但是 - 为什么它是二进制运算符?我所说的只是对除数进行流式处理并对它们进行 sum += 操作。另一个输入究竟代表什么?
  • y值代表累加器值吗?
  • @AmirAfghani reduce 的 javadoc 显示了等效代码及其用途。 y 似乎是流中的每个值。 x是积累。
猜你喜欢
  • 1970-01-01
  • 2018-11-11
  • 1970-01-01
  • 2019-02-09
  • 2015-03-06
  • 2020-11-14
  • 2015-11-05
  • 1970-01-01
  • 2018-09-06
相关资源
最近更新 更多