@cxm-2016
2016-12-27T18:13:26.000000Z
字数 1631
阅读 1641
Kotlin
版本:1
翻译:李颖
有些时候, 能够将一个对象 解构(destructure) 为多个变量, 将会很方便, 比如:
val (name, age) = person
这种语法称为 解构声明(destructuring declaration). 一个解构声明会一次性创建多个变量.
上例中我们声明了两个变量: name
和 age
, 并且可以独立地使用这两个变量:
println(name)
println(age)
解构声明在编译时将被分解为以下代码:
val name = person.component1()
val age = person.component2()
这里的 component1()
和 component2()
函数是 Kotlin 中广泛使用的 约定原则(principle of convention) 的又一个例子(其它例子请参见 +
和 *
操作符, for{: .keyword } 循环, 等等.).
任何东西都可以作为解构声明右侧的被解构值, 只要可以对它调用足够数量的组件函数(component function).
当然, 还可以存在 component3()
和 component4()
等等.
注意, componentN()
函数需要标记为 operator
, 才可以在解构声明中使用.
解构声明还可以使用在 for{: .keyword } 循环中: 当我们说:
for ((a, b) in collection) { ... }
上面的代码将遍历集合中的所有元素, 然后对各个元素调用 component1()
和 component2()
函数, 变量 a
和 b
将得到 component1()
和 component2()
函数的返回值.
举例来说, 假如我们需要从一个函数返回两个值. 比如, 一个是结果对象, 另一个是某种状态值.
在 Kotlin 中有一种紧凑的方法实现这个功能, 我们可以声明一个 数据类, 然后返回这个数据类的一个实例:
data class Result(val result: Int, val status: Status)
fun function(...): Result {
// computations
return Result(result, status)
}
// 现在, 可以这样使用这个函数:
val (result, status) = function(...)
由于数据类会自动声明 componentN()
函数, 因此可以在这里使用解构声明.
注意: 我们也可以使用标准库中的 Pair
类, 让上例中的 function()
函数返回一个 Pair<Int, Status>
实例, 但是, 给你的数据恰当地命名, 通常是一种更好的设计.
遍历一个 map 的最好的方式可能就是:
for ((key, value) in map) {
// 使用 key 和 value 执行某种操作
}
为了让上面的代码正确运行, 我们应该:
iterator()
函数, 使得 map 成为多个值构成的序列,component1()
和 component2()
函数, 使得 map 内的每个元素成为一对值.Kotlin 的标准库也的确实现了这些扩展函数:
operator fun <K, V> Map<K, V>.iterator(): Iterator<Map.Entry<K, V>> = entrySet().iterator()
operator fun <K, V> Map.Entry<K, V>.component1() = getKey()
operator fun <K, V> Map.Entry<K, V>.component2() = getValue()
因此, 你可以在对 map 的 for{: .keyword } 循环中自由地使用解构声明(也可以在对数据类集合的 for{: .keyword } 循环中使用解构声明).