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

用法:

inline fun <S, T : S, K, M : MutableMap<in K, S>> Grouping<T, K>.reduceTo(
    destination: M, 
    operation: (key: K, accumulator: S, element: T) -> S
): M

按键对Grouping源中的元素进行分组,并从组的第二个元素开始依次对每个组的元素应用减少operation,将先前累积的值和当前元素作为参数传递,并将结果存储在给定的destination Map。累加器的初始值是组的第一个元素。

如果 destination 映射已经具有与某个组的键对应的值,则该值用作该组的累加器的初始值,并且该组的第一个元素也受制于 operation

例子:



fun main(args: Array<String>) {
//sampleStart
val animals = listOf("raccoon", "reindeer", "cow", "camel", "giraffe", "goat")
val maxVowels = mutableMapOf<Char, String>()

// grouping by first char and collect only max of contains vowels
val compareByVowelCount = compareBy { s: String -> s.count { it in "aeiou" } }

animals.groupingBy { it.first() }.reduceTo(maxVowels) { _, a, b -> maxOf(a, b, compareByVowelCount) }

println(maxVowels) // {r=reindeer, c=camel, g=giraffe}

val moreAnimals = listOf("capybara", "rat")
moreAnimals.groupingBy { it.first() }.reduceTo(maxVowels) { _, a, b -> maxOf(a, b, compareByVowelCount) }

println(maxVowels) // {r=reindeer, c=capybara, g=giraffe}
//sampleEnd
}

输出:

{r=reindeer, c=camel, g=giraffe}
{r=reindeer, c=capybara, g=giraffe}

参数

operation- 使用以下参数对组的每个后续元素调用的函数:

返回 destination 映射,将每个组的键与累积组元素的结果相关联。