Bootstrap

kotlin中的List集合类

Kotlin的集合分类:

  • 可变集合类(Mutable)
  • 不可变集合类(Immutable)。

集合类存放的都是对象的引用,而非对象本身,我们通常说的集合中的对象指的是集合中对象的引用。集合类型主要有List(列表),Set(集),Map(映射)。

kotlin中List与Java一样都是实现了Collection接口,源码如下:
public interface List<out E> : Collection<E> {
    // Query Operations
    override val size: Int

    override fun isEmpty(): Boolean
    override fun contains(element: @UnsafeVariance E): Boolean
    override fun iterator(): Iterator<E>

    // Bulk Operations
    override fun containsAll(elements: Collection<@UnsafeVariance E>): Boolean

    // Positional Access Operations
    /**
     * Returns the element at the specified index in the list.
     */
    public operator fun get(index: Int): E

    // Search Operations
    /**
     * Returns the index of the first occurrence of the specified element in the list, or -1 if the specified
     * element is not contained in the list.
     */
    public fun indexOf(element: @UnsafeVariance E): Int

    /**
     * Returns the index of the last occurrence of the specified element in the list, or -1 if the specified
     * element is not contained in the list.
     */
    public fun lastIndexOf(element: @UnsafeVariance E): Int

    // List Iterators
    /**
     * Returns a list iterator over the elements in this list (in proper sequence).
     */
    public fun listIterator(): ListIterator<E>

    /**
     * Returns a list iterator over the elements in this list (in proper sequence), starting at the specified [index].
     */
    public fun listIterator(index: Int): ListIterator<E>

    // View
    /**
     * Returns a view of the portion of this list between the specified [fromIndex] (inclusive) and [toIndex] (exclusive).
     * The returned list is backed by this list, so non-structural changes in the returned list are reflected in this list, and vice-versa.
     *
     * Structural changes in the base list make the behavior of the view undefined.
     */
    public fun subList(fromIndex: Int, toIndex: Int): List<E>
}
1.创建不可变List

使用listOf函数来构建一个不可变的List(只读的List),listOf这个构建函数有下面3个重载函数。
源码:

/** Returns a new read-only list of given elements.  The returned list is serializable (JVM). */
public fun <T> listOf(vararg elements: T): List<T> = if (elements.size > 0) elements.asList() else emptyList()

/** Returns an empty read-only list.  The returned list is serializable (JVM). */
@kotlin.internal.InlineOnly
public inline fun <T> listOf(): List<T> = emptyList()

/**
 * Returns an immutable list containing only the specified object [element].
 * The returned list is serializable.
 */
@JvmVersion
public fun <T> listOf(element: T): List<T> = java.util.Collections.singletonList(element)

这些函数创建的List都是是只读的,不可变的、可序列化的。其中,

  • listOf()用于创建没有元素的空List
  • listOf(vararg elements: T)用于创建拥有多个元素的List
  • listOf(element: T)用于创建只有一个元素的List
创建一个空List
val mList: List<Int> = listOf()
println(mList)

打印输出:

[]

创建只有一个元素的List
val mList: List<Int> = listOf(0)
println(mList)

打印输出:

[0]

创建多个元素的List
val mList: List<Int> = listOf(1, 3, 5, 7, 9)
println(mList)

打印输出:

[1, 3, 5, 7, 9]

2.创建可变集合

List的可变集合有两种,源码如下:

/** Returns an empty new [MutableList]. */
@SinceKotlin("1.1")
@kotlin.internal.InlineOnly
public inline fun <T> mutableListOf(): MutableList<T> = ArrayList()

/** Returns an empty new [ArrayList]. */
@SinceKotlin("1.1")
@kotlin.internal.InlineOnly
public inline fun <T> arrayListOf(): ArrayList<T> = ArrayList()

/** Returns a new [MutableList] with the given elements. */
public fun <T> mutableListOf(vararg elements: T): MutableList<T> = if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))

/** Returns a new [ArrayList] with the given elements. */
public fun <T> arrayListOf(vararg elements: T): ArrayList<T> = if (elements.size == 0) ArrayList() else ArrayList(ArrayAsCollection(elements, isVarargs = true))
  • mutableListOf(): MutableList
  • arrayListOf(): ArrayList

在MutableList中,除了继承List中的那些函数外,另外新增了add/addAll、remove/removeAll/removeAt、set、clear、retainAll等更新修改的操作函数。

MutableList源码:
public interface MutableList<E> : List<E>, MutableCollection<E> {
    // Modification Operations
    override fun add(element: E): Boolean

    override fun remove(element: E): Boolean

    // Bulk Modification Operations
    override fun addAll(elements: Collection<E>): Boolean

    /**
     * Inserts all of the elements in the specified collection [elements] into this list at the specified [index].
     *
     * @return `true` if the list was changed as the result of the operation.
     */
    public fun addAll(index: Int, elements: Collection<E>): Boolean

    override fun removeAll(elements: Collection<E>): Boolean
    override fun retainAll(elements: Collection<E>): Boolean
    override fun clear(): Unit

    // Positional Access Operations
    /**
     * Replaces the element at the specified position in this list with the specified element.
     *
     * @return the element previously at the specified position.
     */
    public operator fun set(index: Int, element: E): E

    /**
     * Inserts an element into the list at the specified [index].
     */
    public fun add(index: Int, element: E): Unit

    /**
     * Removes an element at the specified [index] from the list.
     *
     * @return the element that has been removed.
     */
    public fun removeAt(index: Int): E

    // List Iterators
    override fun listIterator(): MutableListIterator<E>

    override fun listIterator(index: Int): MutableListIterator<E>

    // View
    override fun subList(fromIndex: Int, toIndex: Int): MutableList<E>
}

可变集合示例

val mList = mutableListOf(2, 4, 6, 8, 10)
println(mList)
mList.add(0, 0) // 在下标为0的地方添加一个0元素
println(mList)

打印输出:

[2, 4, 6, 8, 10]
[0, 2, 4, 6, 8, 10]

toMutableList()转换函数:

如果已经有了一个不可变的List,想把他转换成可变的List,可直接调用转换函数toMutableList()

// 不可变集合
val mList: List<Int> = listOf(1, 3, 5, 7, 9)
// 调用toMutableList()函数进行转换
val mMutableList = mList.toMutableList()
// 调用可变函数的add()方法
mMutableList.add(11)
// 打印输出
println(mMutableList)

打印输出:

[1, 3, 5, 7, 9, 11]

3.遍历List元素
使用Iterator迭代器遍历List元素
val mList: List<Int> = listOf(0, 1, 2, 3, 4, 5)
val mIndex = mList.iterator()
while (mIndex.hasNext()) {
    println(mIndex.next())
}

打印输出:

0
1
2
3
4
5

使用for循环遍历List元素
val mList: List<Int> = listOf(0, 1, 2, 3, 4, 5)
for (i in mList.indices){
    println(mList[i])
}

打印输出:

0
1
2
3
4
5

逆向循环

for (i in mList.size downTo 0){
    println("$i")
}

打印输出:

6
5
4
3
2
1
0

使用函数withIndex()遍历List元素
val mList: List<Int> = listOf(0, 1, 2, 3, 4, 5)
for ((index, value) in mList.withIndex()) {
    println("下标 = $index\t值 = $value")
}

打印输出:

下标 = 0 值 = 0
下标 = 1 值 = 1
下标 = 2 值 = 2
下标 = 3 值 = 3
下标 = 4 值 = 4
下标 = 5 值 = 5

使用forEach遍历List元素
val mList: List<Int> = listOf(0, 1, 2, 3, 4, 5)
mList.forEach {
    println(it)
}

打印输出:

0
1
2
3
4
5

4.常见的List元素操作函数
add, remove, set, clear

这几个操作符与Java中的List一样。

retainAll

取两个集合交集:

val mList1 = mutableListOf(0, 1, 3, 5, 7, 9)
val mList2 = mutableListOf(0, 2, 4, 6, 8, 10)
mList1.retainAll(mList2)
println(mList1)

打印输出:

[0]

contains(element: T): Boolean

判断集合中是否有指定元素,有就返回true,否则返回false 。

val mList = mutableListOf(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
// 取集合中存在的元素
println(mList.contains(5))
// 取集合中不存在的元素
println(mList.contains(20))

打印输出:

true
false

elementAt(index: Int): T

查找下标对应的元素,如果下标越界会抛IndexOutOfBoundsException。

val mList = mutableListOf(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10)
println("下标为5的元素值:${mList.elementAt(5)}")

打印输出:

下标为5的元素值:5

elementAtOrElse(index: Int, defaultValue: (Int) -> T): T

查找下标对应元素,如果越界会根据方法返回默认值。

val mList = mutableListOf(0,1,2,3,4,5)
println(mList.elementAtOrElse(5, {0}))
println(mList.elementAtOrElse(6, {0}))

打印输出:

5
0

elementAtOrNull(index: Int): T?

查找下标对应元素,如果越界就返回null

val mList = mutableListOf(0,1,2,3,4,5)
println(mList.elementAtOrNull(6))

打印输出:

null

first()

返回集合第1个元素,如果是空集,抛出异常java.util.NoSuchElementException: List is empty.

val mList = mutableListOf(0,1,2,3,4,5)
println(mList.first())

打印输出:

0

firstOrNull(): T?

返回集合第1个元素,如果是空集, 对空指针异常处理的函数,如果集合为空,则返回null。

val mList = listOf<Int>()
println(mList.firstOrNull())

打印输出:

null

first(predicate: (T) -> Boolean): T

返回符合条件的第一个元素,没有则抛异常NoSuchElementException 。

val mList = listOf(1, 2, 3)
println(mList.first { it % 2 == 0 })

打印输出:

2

对应的有针对异常处理的函数firstOrNull(predicate: (T) -> Boolean): T? ,返回符合条件的第一个元素,没有就返回null

indexOf(element: T): Int

返回指定元素的下标,没有就返回-1

val mList = listOf(1, 2, 3)
println(mList.indexOf(3))
println(mList.indexOf(0))

打印输出:

2
-1

indexOfFirst(predicate: (T) -> Boolean): Int

返回第一个符合条件的元素的下标,没有就返回-1 。

val mList = listOf(1, 2, 3)
println(mList.indexOfFirst { it == 2})

集合中元素2对应的下标是1,所以打印输出:

1

indexOfLast(predicate: (T) -> Boolean): Int

返回最后一个符合条件的元素下标,没有就返回-1 。

val mList = listOf("java for android", "gradle for android", "kotlin for android")
println(mList.indexOfLast { it.contains("android")})

打印输出:

2

集合元素kotlin for android的下标刚好对应的是2 。

last()

返回集合最后一个元素,空集则抛出异常NoSuchElementException。

val mList = listOf("java for android", "gradle for android", "kotlin for android")
println(mList.last())

打印输出:

kotlin for android

last(predicate: (T) -> Boolean): T

返回符合条件的最后一个元素,没有就抛NoSuchElementException

val mList = listOf("java for android", "gradle for android", "kotlin for android")
println(mList.last { it.contains("android") })

打印输出:

kotlin for android

lastOrNull(predicate: (T) -> Boolean): T?

返回符合条件的最后一个元素,没有就返回null

val mList = listOf("java for android", "gradle for android", "kotlin for android")
println(mList.lastOrNull { it.contains("android") })
println(mList.lastOrNull { it.contains("JavaScript") })

打印输出:

kotlin for android
null

lastIndexOf(element: T): Int

返回符合条件的最后一个元素的下标,没有就返回-1

val mList = listOf("java for android", "android", "kotlin", "android")
println(mList.lastIndexOf("android"))
println(mList.lastIndexOf("JavaScript"))

打印输出:

3
-1

single(): T

该集合如果只有1个元素,则返回该元素。为空时会抛出NoSuchElementException 异常,存在多个元素时会抛 IllegalArgumentException异常。

val mList = listOf(1)
println(mList.single())

打印输出:

1

singleOrNull(): T?

返回符合条件单个元素, 如果集合为空或者有多个元素,则返回null

val mList = listOf(1, 2)
println(mList.singleOrNull())

打印输出:

null

single(predicate: (T) -> Boolean): T

返回符合条件的单个元素,如有没有符合的抛异常NoSuchElementException,或超过一个的抛异常IllegalArgumentException。

val mList = listOf(1)
println(mList.single { it == 1 })
println(mList.single { it == 2 })

打印输出:

1
Exception in thread “main” java.util.NoSuchElementException: Collection contains no element matching the predicate.
at KotlinUtilsTestKt.main(KotlinUtilsTest.kt:48)

singleOrNull(predicate: (T) -> Boolean): T?

返回符合条件单个元素,如果未找到符合的元素或找到多个元素,则返回null。

val mList = listOf(1, 2)
println(mList.singleOrNull { it == 2 })

打印输出:

2

5.List集合运算的基本函数
any(): Boolean

判断集合元素,如果集合为空,返回false, 集合中存有一个或多个元素时返回true

val mList1 = arrayListOf(1, 2, 3, 4, 5)
val mList2: ArrayList<Int> = arrayListOf()
println(mList1.any())
println(mList2.any())

打印输出:

true
false

any(predicate: (T) -> Boolean): Boolean

判断集合元素,如果集合为空或者没有符号条件的元素返回false, 集合中存有一个或多个元素符合条件时返回true

val mList = arrayListOf(1, 2, 2, 3, 4, 5)
println(mList.any { it == 2})

打印输出:

true

all(predicate: (T) -> Boolean): Boolean

当且仅当该集合中所有元素都满足条件时,返回true;否则都返回false。

val mList = arrayListOf(0, 2, 4, 6, 8)
println(mList.all { it % 2 == 0 })

打印输出:

true

val mList = arrayListOf(0, 1, 2, 3, 4)
println(mList.all { it % 2 == 0 })

打印输出:

false

none(): Boolean

如果集合中没有元素,则返回true,否则返回false。

val mList = arrayListOf(0, 1, 2, 3, 4)
println(mList.none())

打印输出:

false

none(predicate: (T) -> Boolean): Boolean

如果集合中没有符合匹配条件的元素,返回true,否则返回false 。

val mList = arrayListOf(0, 1, 2, 3, 4)
println(mList.none { it == 5 })

打印输出:

true

count(): Int

返回集合元素个数

val mList = arrayListOf(0, 1, 2, 3, 4)
println(mList.count())

打印输:

5

count(predicate: (T) -> Boolean): Int

返回符合匹配条件的元素的个数

val mList = arrayListOf(0, 1, 2, 3, 4)
println(mList.count { it % 2 == 0 })

打印输出:

3

max, min 查询最大,最小元素,空集返回null

max函数定义

public fun <T : Comparable<T>> Iterable<T>.max(): T? {
    val iterator = iterator()
    if (!iterator.hasNext()) return null
    var max = iterator.next()
    while (iterator.hasNext()) {
        val e = iterator.next()
        if (max < e) max = e
    }
    return max
}

通过max函数源代码定义看出,max函数是通过迭代器遍历集合进行比较,返回最大元素。

min函数定义

public fun <T : Comparable<T>> Iterable<T>.min(): T? {
    val iterator = iterator()
    if (!iterator.hasNext()) return null
    var min = iterator.next()
    while (iterator.hasNext()) {
        val e = iterator.next()
        if (min > e) min = e
    }
    return min
}

通过min函数源代码定义看出,min函数也是通过迭代器遍历集合进行比较,返回最小元素。

val mList = arrayListOf(0, 1, 2, 3)
println(mList.max())
println(mList.min())

打印输出:

3
0

6.过滤操作函数
take(n: Int): List

take函数是根据传入的参数挑出该集合前n个元素的子集合

val mList = arrayListOf(0, 1, 2, 3)
val mNewList = mList.take(2)
println(mNewList)

打印mNewList集合元素:

[0, 1]

7.映射操作符
map(transform: (T) -> R): List

将集合中的元素通过转换函数transform映射后的结果,存到一个集合中返回。

val mList = mutableListOf(1, 3, 2, 4)
println(mList.map { it + 1 })

打印输出:

[2, 4, 3, 5]

mapNotNull(transform: (T) -> R?)

遍历集合每个元素,得到通过函数算子transform映射之后的值,剔除掉这些值中的null,返回一个无null元素的集合。

val mList = mutableListOf(1, null, 3, null, 2, 4)
println(mList.mapNotNull { it })

打印输出:

[1, 3, 2, 4]

8.排序操作符
reversed(): List

倒序排列集合元素。如:[1, 2, 7, 6, 4, 5]排列后为:[5, 4, 6, 7, 2, 1]。

val mList = listOf(1, 3, 2, 4)
println(mList.reversed())

打印输出:

[4, 2, 3, 1]

sorted(): List和sortedDescending(): List

升序排序和降序排序。

val mList = listOf(1, 3, 2, 4)
println(mList.sorted())
println(mList.sortedDescending())

打印输出:

[1, 2, 3, 4]
[4, 3, 2, 1]

sortedBy和sortedByDescending

可变集合MutableList的排序操作。根据函数映射的结果进行升序排序和降序排序。

val mList = mutableListOf(1, 3, 2, 4)
println(mList.sorted())
println(mList.sortedDescending())

打印输出:

[1, 2, 3, 4]
[4, 3, 2, 1]

9.生产操作符
zip(other: Iterable): List
val mList3 = arrayListOf("x1", "x2", "x3", "x4")
val mList4 = arrayListOf("y1", "y2", "y3")
println(mList3.zip(mList4))

打印输出:

[(x1, y1), (x2, y2), (x3, y3)]

plus(elements: Iterable): List

合并两个List

val mList1 = arrayListOf(0, 1, 2, 3)
val mList2 = arrayListOf(4, 5, 6, 7, 8)
println(mList1.plus(mList2))

打印输出:

[0, 1, 2, 3, 4, 5, 6, 7, 8]

这段时间一边查资料一边学习,真心说kotlin这个语言设计的很好,而且kotlin中可变集合与不可变集合提供的函数方法特别丰富。

;