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

用法:

inline fun <T, K, R, M : MutableMap<in K, R>> Grouping<T, K>.aggregateTo(
    destination: M, 
    operation: (key: K, accumulator: R?, element: T, first: Boolean) -> R
): M

通过键对来自Grouping 源的元素进行分组,并将operation 依次应用于每个组的元素,将先前累积的值和当前元素作为参数传递,并将结果存储在给定的destination 映射中。

每个元素的键由Grouping.keyOf 函数提供。

例子:



fun main(args: Array<String>) {
//sampleStart
val numbers = listOf(3, 4, 5, 6, 7, 8, 9)

val aggregated = numbers.groupingBy { it % 3 }.aggregateTo(mutableMapOf()) { key, accumulator: StringBuilder?, element, first ->
    if (first) // first element
        StringBuilder().append(key).append(":").append(element)
    else
        accumulator!!.append("-").append(element)
}

println(aggregated.values) // [0:3-6-9, 1:4-7, 2:5-8]

// aggregated is a mutable map
aggregated.clear()
//sampleEnd
}

输出:

[0:3-6-9, 1:4-7, 2:5-8]

参数

operation-

使用以下参数对每个元素调用的函数:

  • key :该元素所属组的键;
  • accumulator :组累加器的当前值,如果是组中第一个遇到的element,则可以是null
  • element :正在聚合的源元素;
  • first :指示它是否是组中遇到的第一个 element

如果 destination 映射已经具有与某个键对应的值,则为该键聚合的元素永远不会被视为 first

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