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 映射。