美文网首页Kotlin
Kotlin-2 | 集合

Kotlin-2 | 集合

作者: Mindjet | 来源:发表于2017-08-30 15:09 被阅读98次

集合的声明

集合的声明使用 mapOflistOfsetOf 等。

val map = mapOf<Int, Int>(0 to 1, 1 to 2, 2 to 3)
val list = listOf<Int>(0, 1, 2)
val set = setOf<Int>(0, 1, 2)

当然它们也可以不指定泛型,如:

val list = listOf(0, "string", true)

使用mapOflistOfsetOf 声明的集合都不能删除或者添加元素,要想让元素可以删除和添加,应该使用对应的 mutable 类型的声明方式:mutableMapOfmutableListOfmutableSetOf

集合的操作

在大多数遍历的操作符中,it 代表着当前的元素。

遍历

val list = listOf(0, 1, 2, 3, 4, 5, 6, 7, 8, 9)

list.any { it % 5 == 0 }
list.all { it >= 0 }
list.none { it > 9 }
list.count { it % 2 == 0 }
list.fold(100) { total, next -> total + 1 }
list.foldRight(100) { next, total -> total + next }
list.reduce { total, next -> total + next }
list.reduceRight { next, total -> 1 + total }
list.forEach { println(it) }
list.forEachIndexed { index, item -> println("$index: $item") }
list.max()
list.maxBy { -it }
list.forEach {}
list.sum()
list.sumBy { it + 2 }
  • any,如果集合中有任何一个元素满足条件,即返回 true,否则返回 false
  • all,集合中所有元素满足条件才能返回 true,否则返回 false
  • none, 与 all 操作符相反,当集合中所有元素逗不满足条件时才返回 true,否则返回 false
  • count,计算集合中所有满足条件的元素数目并返回
  • fold,提供一个初始值作为基数,然后从左往右遍历集合,回调函数中,第一个参数代表当前的基数,第二个参数代表下一个元素,回调函数中返回的值作为新的基数进行下一轮遍历,最终整个操作符返回最后的基数
  • foldRight,与 fold 类似,但是方向是从右到左,并且回调函数的两个参数位置互换
  • reduce/reduceRight,与 fold/foldRight 类似,但是不提供初始基数
  • forEach/forEachIndexed,遍历/带有 index 的遍历,没有返回值
  • max,顾名思义,返回集合中的最大值
  • maxBy,根据规则计算出最大值,返回最大值的原始值
  • sum,返回元素的总和,仅适用于 listOf<Int> 等可以相加的元素集合
  • sumBy,根据提供的规则来计算总和并返回

过滤

val list = listOf(0, 1, 2, 3, 4, 5, 6, 7, 8, 9)

list.drop(2)
list.dropLast(2)
list.dropWhile { it % 3 != 0 }
list.dropLastWhile { it % 3 != 0 }
list.filter { it % 2 == 0 }
list.filterNot { it % 2 == 0 }
list.filterNotNull()
list.take(3)
list.takeLast(4)
list.takeWhile { it < 3 }
list.takeLastWhile { it > 5 }
  • drop/dropLast,舍弃掉前几个/后几个元素
  • dropWhile/dropLastWhile,从左边/右边开始舍弃元素,直到当前元素不满足条件
  • filter,过滤掉不满足条件的元素
  • filterNot,与 filter 相反,过滤掉满足条件的元素
  • filterNotNull,过滤掉 null 的元素
  • take/takeLast,保留前几个/后几个元素
  • takeWhile/takeLastWhile,从左边/右边开始保留元素,直到当前元素不满足条件

映射

val list = listOf(0, 1, 2, 3, 4, 5, 6, 7, 8, 9)

list.flatMap { listOf(it, it * 2) }
list.map { listOf(it, it * 2) }
list.groupBy { if (it % 2 == 0) "even" else "odd" }
list.mapIndexed { index, item -> item + index }
  • flatMap,返回一个 list 并插入到当前的位置中,最后返回整个变换后的 list
  • map,返回一个元素(可能是 list)到当前位置,最后返回整个变换后的 list
  • mapIndexed,带有 indexmap 操作
  • groupBy,根据规则进行分组,并返回分组后的对象

根据上面的操作,flatMapmapgroupBy 分别输出:

//flatMap
[0, 0, 1, 2, 2, 4, 3, 6, 4, 8, 5, 10, 6, 12, 7, 14, 8, 16, 9, 18]   
//map
[[0, 0], [1, 2], [2, 4], [3, 6], [4, 8], [5, 10], [6, 12], [7, 14], [8, 16], [9, 18]
//groupBy
{even=[0, 2, 4, 6, 8], odd=[1, 3, 5, 7, 9]}     

由此可以看出 flatMapmap 的区别,后者是直接将变换后的内容替换掉原先的位置上的内容,而前者是将变换后的内容转换成与原先位置上相同性质的内容,即原先一维 list,经过变换后还是一维的,这便是 flat 的特点所在。

排序

val list = listOf(0, 1, 2, 3, 4, 5, 6, 7, 8, 9)

list.reversed()
list.sorted()
list.sortedBy { it % 2 }
list.sortedDescending()
  • sorted/reversed,返回正序/倒序排列的集合
  • sortedBy,根据规则进行位置排序,并返回排序后的集合
  • sortedDescending,相当于 reversed

Sum up

以上就是关于集合和集合操作的介绍,主要是关注于 list 的操作,若有缺漏,敬请斧正。如果你有更好的内容,欢迎补充。

相关文章

网友评论

    本文标题:Kotlin-2 | 集合

    本文链接:https://www.haomeiwen.com/subject/bdutjxtx.html