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