Kotlin Collection KTX:让你的集合操作如丝般顺滑
除了 Collection KTX,Kotlin 还提供了许多其他扩展库,例如 Android KTX、Coroutines、Serialization KTX 等,它们都可以大大简化我们的开发流程。在接下来的文章中,我们还将为您介绍这些扩展库的详细信息,让你的 Kotlin 开发之路更加畅通无阻
使用
dependencies {
implementation "androidx.collection:collection-ktx:1.2.0"
}
用法合集
Collection 扩展函数
filterNot()
:过滤掉指定元素后的新 Collection。filterNotNull()
:过滤掉null
元素后的新 Collection。
List 扩展函数
sorted()
:按自然顺序排序后的新 List。sortedBy()
:按指定方式排序后的新 List。sortedDescending()
:按自然顺序降序排序后的新 List。sortedByDescending()
:按指定方式降序排序后的新 List。distinct()
:去重后的新 List。distinctBy()
:按指定方式去重后的新 List。minus()
:删除指定元素后的新 List。plus()
:添加指定元素后的新 List。drop()
:去掉前几个元素后的新 List。dropWhile()
:去掉符合指定条件的元素后的新 List。take()
:前几个元素组成的新 List。takeWhile()
:符合指定条件的元素组成的新 List。partition()
:按指定条件分隔后的 Pair。groupBy()
:按指定方式分组后的 Map。associate()
:按指定方式关联后的新 Map。associateBy()
:按指定方式关联键后的新 Map。associateWith()
:按指定方式关联值后的新 Map。zip()
:按指定方式组合后的新 List。
MutableList 扩展函数
removeLast()
:移除最后一个元素,并返回该元素。removeFirst()
:移除第一个元素,并返回该元素。move()
:将指定元素移动到新位置。
Set 扩展函数
minus()
:删除指定元素后的新 Set。plus()
:添加指定元素后的新 Set。partition()
:按指定条件分隔后的 Pair。groupBy()
:按指定方式分组后的 Map。associate()
:按指定方式关联后的新 Map。associateBy()
:按指定方式关联键后的新 Map。associateWith()
:按指定方式关联值后的新 Map。
MutableSet 扩展函数
remove()
:移除指定元素,并返回是否移除成功。retainAll()
:仅保留符合指定条件的元素。addAll()
:添加指定元素后的新 MutableSet。
Map 扩展函数
minus()
:删除指定键对应的元素后的新 Map。plus()
:添加指定键值对后的新 Map。partition()
:按指定条件分隔后的 Pair。filterKeys()
:按指定条件过滤键后的新 Map。filterValues()
:按指定条件过滤值后的新 Map。mapKeys()
:按指定方式映射键后的新 Map。mapValues()
: 按指定方式映射值后的新map
MutableMap 扩展函数
remove()
:移除指定键对应的元素,并返回该元素。putAll()
:添加指定键值对后的新 MutableMap。putIfAbsent()
:仅在指定键不存在时添加指定键值对。compute()
:更新指定键对应的元素,并返回更新后的值。computeIfAbsent()
:仅在指定键不存在时更新该键对应的元素。computeIfPresent()
:仅在指定键存在时更新该键对应的元素。
Iterable 扩展函数
reduceOrNull()
:对所有元素进行指定操作,如果为 null 则返回 null。reduceIndexedOrNull()
:对所有元素进行指定操作,同时考虑元素的索引,如果为 null 则返回 null。foldOrNull()
:对所有元素进行指定操作并给定初始值,如果为 null 则返回 null。foldIndexedOrNull()
:对所有元素进行指定操作并给定初始值,同时考虑元素的索引,如果为 null 则返回 null。
ListIterator 扩展函数
previousOrNull()
:返回上一个元素,如果不存在则返回 null。
Sequence 扩展函数
reduceOrNull()
:对所有元素进行指定操作,如果为 null 则返回 null。reduceIndexedOrNull()
:对所有元素进行指定操作,同时考虑元素的索引,如果为 null 则返回 null。foldOrNull()
:对所有元素进行指定操作并给定初始值,如果为 null 则返回 null。foldIndexedOrNull()
:对所有元素进行指定操作并给定初始值,同时考虑元素的索引,如果为 null 则返回 null。distinct()
:去重后的新 Sequence。distinctBy()
:按指定方式去重后的新 Sequence。filterNotNull()
:过滤掉null
元素后的新 Sequence。filterNot()
:过滤掉指定元素后的新 Sequence。partition()
:按指定条件分隔后的 Pair。sorted()
:按自然顺序排序后的新 Sequence。sortedBy()
:按指定方式排序后的新 Sequence。sortedDescending()
:按自然顺序降序排序后的新 Sequence。sortedByDescending()
:按指定方式降序排序后的新 Sequence。take()
:前几个元素组成的新 Sequence。takeWhile()
:符合指定条件的元素组成的新 Sequence。zip()
:按指定方式组合后的新 Sequence
了解工具的尿性
工具的职责就是提高工作效率
使用 Collection KTX 可以大大简化集合操作的代码,使代码更加简洁易读,同时可以提高代码的可维护性
在使用集合时,应该尽可能使用 Kotlin 标准库中的函数和 Collection KTX 中的扩展函数,而不是手写循环或通过 Java API 进行操作,这可以减少代码量和提高代码可读性。
了解不同的集合类型及其特性,选择合适的集合类型可以使代码更加高效。例如,如果需要频繁添加或删除元素,则应该使用可变集合类型。
避免频繁进行集合类型的转换,因为这会导致性能降低。如果需要对集合进行不同的操作,可以考虑使用不同的集合类型来解决。
尽量避免对空集合进行操作,因为这可能会导致空指针异常。在使用 Collection KTX 时,可以使用非空断言或者空安全操作符来处理可能为空的集合。
当然使用时也要注意,kotlin 的扩展函数让代码的可读性要求增高了少,所以用的使用为了能保证团队的统一,因该注意:
对于代码中的扩展函数,应该在函数名称中体现其作用,以便其他开发者更容易理解代码。例如,“find”函数可以改名为“findFirstOrNull”或“findLastOrNull”。
在使用 Collection KTX 时,应该注意性能问题。某些操作可能会导致性能下降,例如对大型集合进行循环和操作,因此应该考虑使用 Sequence 和 Flow 来提高性能。
避免重复操作。使用 Collection KTX 可以使代码更加简洁和易读,但是不应该过度使用,如果某个操作已经通过一个函数实现了,就不要再手动写同样的操作。