5.3.1 创建不可变List
我们可以使用listOf
函数来构建一个不可变的List(read-only,只读的List)。它定义在libraries/stdlib/src/kotlin/collections/Collections.kt
里面。关于listOf
这个构建函数有下面3个重载函数:
@kotlin.internal.InlineOnly
public inline fun <T> listOf(): List<T> = emptyList()
public fun <T> listOf(vararg elements: T): List<T> = if (elements.size > 0) elements.asList() else emptyList()
@JvmVersion
public fun <T> listOf(element: T): List<T> = java.util.Collections.singletonList(element)
这些函数创建的List都是是只读的(readonly,也就是不可变的immutable )、可序列化的。
其中,
listOf()
用于创建没有元素的空ListlistOf(vararg elements: T)
用于创建只有一个元素的ListlistOf(element: T)
用于创建拥有多个元素的List
我们使用代码示例分别来演示其用法:
首先,我们使用listOf()
来构建一个没有元素的空的List:
>>> val list:List<Int> = listOf()
>>> list
[]
>>> list::class
class kotlin.collections.EmptyList
注意,这里的变量的类型不能省略,否则会报错:
>>> val list = listOf()
error: type inference failed: Not enough information to infer parameter T in inline fun <T> listOf(): List<T>
Please specify it explicitly.
val list = listOf()
^
因为这是一个泛型函数。关于泛型,我们将在下一章中介绍。
其中,EmptyList
是一个 internal object EmptyList
, 这是Kotlin内部定义的一个默认空的object List类。
下面,我们再来创建一个只有1个元素的List:
>>> val list = listOf(1)
>>> list::class
class java.util.Collections$SingletonList
我们可以看出,它实际上是调用Java的java.util.Collections
里面的singletonList
方法:
public static <T> List<T> singletonList(T o) {
return new SingletonList<>(o);
}
我们再来创建一个有多个元素的List:
>>> val list = listOf(0,1, 2, 3, 4, 5, 6,7,8,9)
>>> list
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> list::class
class java.util.Arrays$ArrayList
>>> list::class.java
它调用的是
fun <T> listOf(vararg elements: T): List<T> = if (elements.size > 0) elements.asList() else emptyList()
这个函数。其中,asList
函数是Array
的扩展函数:
public fun <T> Array<out T>.asList(): List<T> {
return ArraysUtilJVM.asList(this)
}
而这个ArraysUtilJVM
是一个Java类,里面实际上调用的是java.util.Arrays
和java.util.List
:
package kotlin.collections;
import java.util.Arrays;
import java.util.List;
class ArraysUtilJVM {
static <T> List<T> asList(T[] array) {
return Arrays.asList(array);
}
}
另外,我们还可以直接使用arrayListOf
函数来创建一个Java中的ArrayList对象实例:
>>> val list = arrayListOf(0,1,2,3)
>>> list
[0, 1, 2, 3]
>>> list::class
class java.util.ArrayList
>>> val list = listOf(0,1, 2, 3, 4, 5, 6,7,8,9)
>>> list::class
class java.util.Arrays$ArrayList
这个函数定义在libraries/stdlib/src/kotlin/collections/Collections.kt
类中:
@SinceKotlin("1.1")
@kotlin.internal.InlineOnly
public inline fun <T> arrayListOf(): ArrayList<T> = ArrayList()
同样的处理方式,这里的ArrayList()
是Java中的java.util.ArrayList
的类型别名:
@SinceKotlin("1.1") public typealias ArrayList<E> = java.util.ArrayList<E>