runningReduce所在位置是kotlin.sequences.runningReduce,其相关用法介绍如下。

用法:

fun <S, T : S> Sequence<T>.runningReduce(
    operation: (acc: S, T) -> S
): Sequence<S>

返回一个序列,其中包含通过从左到右将operation 应用于每个元素和从该序列的第一个元素开始的当前累加器值生成的连续累加值。

请注意,传递给operation 函数的acc 值不应被改变;否则会影响结果序列中的前一个值。

例子:

import kotlin.test.*

fun main(args: Array<String>) {
//sampleStart
val strings = listOf("a", "b", "c", "d")
println(strings.runningReduce { acc, string -> acc + string }) // [a, ab, abc, abcd]
println(strings.runningReduceIndexed { index, acc, string -> acc + string + index }) // [a, ab1, ab1c2, ab1c2d3]

println(emptyList<String>().runningReduce { _, _ -> "X" }) // []
//sampleEnd
}

输出:

[a, ab, abc, abcd]
[a, ab1, ab1c2, ab1c2d3]
[]

参数

operation-

获取当前累加器值和元素的函数,并计算下一个累加器值。

操作是 intermediatestateless