associateBy所在位置是kotlin.text.associateBy,其相關用法介紹如下。

用法一

inline fun <K> CharSequence.associateBy(
    keySelector: (Char) -> K
): Map<K, Char>

返回一個Map,其中包含給定字符序列中的字符,該字符序列由應用於每個字符的keySelector 函數返回的鍵索引。

如果任意兩個字符具有由keySelector 返回的相同鍵,則最後一個將添加到Map中。

返回的映射保留原始字符序列的條目迭代順序。

例子:

import java.util.Locale
import kotlin.test.*

fun main(args: Array<String>) {
//sampleStart
val string = "bonne journée"
// associate each character by its code
val result = string.associateBy { char -> char.code }
// notice each char code occurs only once
println(result) // {98=b, 111=o, 110=n, 101=e, 32= , 106=j, 117=u, 114=r, 233=é}
//sampleEnd
}

輸出:

{98=b, 111=o, 110=n, 101=e, 32= , 106=j, 117=u, 114=r, 233=é}

用法二

inline fun <K, V> CharSequence.associateBy(
    keySelector: (Char) -> K, 
    valueTransform: (Char) -> V
): Map<K, V>

返回一個Map,其中包含由valueTransform 提供的值並由應用於給定字符序列的字符的keySelector 函數索引。

如果任意兩個字符具有由keySelector 返回的相同鍵,則最後一個將添加到Map中。

返回的映射保留原始字符序列的條目迭代順序。

例子:

import java.util.Locale
import kotlin.test.*

fun main(args: Array<String>) {
//sampleStart
val string = "bonne journée"
// associate each character by the code of its upper case equivalent and transform the character to upper case
val result = string.associateBy({ char -> char.uppercaseChar().code }, { char -> char.uppercaseChar() })
// notice each char code occurs only once
println(result) // {66=B, 79=O, 78=N, 69=E, 32= , 74=J, 85=U, 82=R, 201=É}
//sampleEnd
}

輸出:

{66=B, 79=O, 78=N, 69=E, 32= , 74=J, 85=U, 82=R, 201=É}