Kotlin Map扩展函数使用指南

常见 List 扩展函数及使用实例

将使用一个基础 Map 作为示例:val map = mapOf("a" to 1, "b" to 2, "c" to 3)。所有代码示例都基于这个 Map。

1. mapKeys 函数

  • 函数签名fun <K, V, R> Map<out K, V>.mapKeys(transform: (Map.Entry<K, V>) -> R): Map<R, V>
  • 意思 :转换 Map 的键(key),生成一个新 Map。新 Map 的键由 transform 函数定义,值保持不变。
  • 代码实例:将键转换为大写形式。
kotlin 复制代码
val newMap = map.mapKeys { it.key.uppercase() }
println(newMap) // 输出: {A=1, B=2, C=3}

2. mapValues 函数

  • 函数签名fun <K, V, R> Map<out K, V>.mapValues(transform: (Map.Entry<K, V>) -> R): Map<K, R>
  • 意思 :转换 Map 的值(value),生成一个新 Map。新 Map 的键保持不变,值由 transform 函数定义。
  • 代码实例:将值乘以 2。
kotlin 复制代码
val newMap = map.mapValues { it.value * 2 }
println(newMap) // 输出: {a=2, b=4, c=6}

3. filterKeys 函数

  • 函数签名fun <K, V> Map<out K, V>.filterKeys(predicate: (K) -> Boolean): Map<K, V>
  • 意思 :过滤 Map 的键,只保留满足 predicate 条件的键值对,生成一个新 Map。
  • 代码实例:只保留键以 "a" 开头的条目。
kotlin 复制代码
val newMap = map.filterKeys { it.startsWith("a") }
println(newMap) // 输出: {a=1}

4. filterValues 函数

  • 函数签名fun <K, V> Map<out K, V>.filterValues(predicate: (V) -> Boolean): Map<K, V>
  • 意思 :过滤 Map 的值,只保留满足 predicate 条件的键值对,生成一个新 Map。
  • 代码实例:只保留值大于 1 的条目。
kotlin 复制代码
val newMap = map.filterValues { it > 1 }
println(newMap) // 输出: {b=2, c=3}

5. filter 函数

  • 函数签名fun <K, V> Map<out K, V>.filter(predicate: (Map.Entry<K, V>) -> Boolean): Map<K, V>
  • 意思 :基于整个键值对(entry)进行过滤,只保留满足 predicate 条件的条目,生成一个新 Map。比 filterKeysfilterValues 更灵活。
  • 代码实例:只保留键长度大于 1 且值为奇数的条目。
kotlin 复制代码
val newMap = map.filter { (key, value) -> key.length > 1 && value % 2 != 0 }
// 注意:示例 Map 的键都是单字符,所以这里可能无输出。实际使用时,可调整 Map。
val customMap = mapOf("apple" to 3, "banana" to 4)
val filteredMap = customMap.filter { (key, value) -> key.length > 5 && value % 2 == 0 }
println(filteredMap) // 输出: {banana=4}(如果键长度大于5且值为偶)

6. getOrDefault 函数

  • 函数签名fun <K, V> Map<out K, V>.getOrDefault(key: K, defaultValue: V): V
  • 意思:安全地获取值。如果键存在,则返回对应的值;如果键不存在,则返回指定的默认值。
  • 代码实例:获取键 "d" 的值,如果不存在则返回 -1。
kotlin 复制代码
val value = map.getOrDefault("d", -1)
println(value) // 输出: -1(因为 "d" 不在原始 Map 中)

7. getOrElse 函数

  • 函数签名fun <K, V> Map<out K, V>.getOrElse(key: K, defaultValue: () -> V): V
  • 意思 :安全地获取值。如果键存在,则返回对应的值;如果键不存在,则计算并返回由 defaultValue 函数生成的值。比 getOrDefault 更灵活,因为默认值可以动态计算。
  • 代码实例:获取键 "d" 的值,如果不存在则计算默认值(例如,字符串长度)。
kotlin 复制代码
val value = map.getOrElse("d") { "default".length } // 默认值计算为 7
println(value) // 输出: 7

8. plus 操作符(扩展函数形式)

  • 函数签名operator fun <K, V> Map<out K, V>.plus(pair: Pair<K, V>): Map<K, V>(也支持多个 Pair 或 Map)
  • 意思 :添加一个或多个键值对,生成一个新 Map。原始 Map 不变。使用 + 操作符调用。
  • 代码实例:添加一个新键值对 "d" to 4。
kotlin 复制代码
val newMap = map + ("d" to 4)
println(newMap) // 输出: {a=1, b=2, c=3, d=4}

9. minus 操作符(扩展函数形式)

  • 函数签名operator fun <K, V> Map<out K, V>.minus(key: K): Map<K, V>(也支持多个键)
  • 意思 :移除一个或多个键值对,生成一个新 Map。原始 Map 不变。使用 - 操作符调用。
  • 代码实例:移除键 "b"。
kotlin 复制代码
val newMap = map - "b"
println(newMap) // 输出: {a=1, c=3}

10. forEach 函数

  • 函数签名fun <K, V> Map<out K, V>.forEach(action: (Map.Entry<K, V>) -> Unit)
  • 意思 :遍历 Map 的每个键值对,执行 action 操作。无返回值,用于副作用(如打印)。
  • 代码实例:打印每个键值对。
kotlin 复制代码
map.forEach { (key, value) -> println("Key: $key, Value: $value") }
// 输出:
// Key: a, Value: 1
// Key: b, Value: 2
// Key: c, Value: 3

11. onEach 函数

  • 函数签名fun <K, V> Map<out K, V>.onEach(action: (Map.Entry<K, V>) -> Unit): Map<K, V>
  • 意思 :遍历 Map 的每个键值对,执行 action 操作,并返回原始 Map。常用于链式调用中执行中间操作。
  • 代码实例:打印每个条目后,返回原始 Map 进行后续操作。
kotlin 复制代码
val processedMap = map.onEach { println("Processing: ${it.key}") }
  .mapValues { it.value * 10 }
println(processedMap) // 输出: {a=10, b=20, c=30},同时打印处理过程
相关推荐
PineappleCoder1 天前
性能数据别再瞎轮询了!PerformanceObserver 异步捕获 LCP/CLS,不卡主线程
前端·性能优化
PineappleCoder1 天前
告别字体闪烁 / 首屏卡顿!preload 让关键资源 “高优先级” 提前到
前端·性能优化
m0_471199631 天前
【vue】通俗详解package-lock文件的作用
前端·javascript·vue.js
hnlgzb1 天前
安卓app开发,如何快速上手kotlin和compose的开发?
android·开发语言·kotlin
alexhilton1 天前
Jetpack Compose 2025年12月版本新增功能
android·kotlin·android jetpack
GIS之路1 天前
GDAL 读取KML数据
前端
今天不要写bug1 天前
vue项目基于vue-cropper实现图片裁剪与图片压缩
前端·javascript·vue.js·typescript
骥龙1 天前
3.10、构建网络防线:防火墙、WAF 与蜜罐实战
服务器·网络·数据库·网络安全
用户47949283569151 天前
记住这张时间线图,你再也不会乱用 useEffect / useLayoutEffect
前端·react.js