原文地址
Kotlin有三种结构型的跳转表达式:
- return.默认返回最近的闭包函数和匿名函数
- break.终结最近的闭包循环
- continue.进行下一步最近的闭包循环
所有的这些表达式能被用作更大的表达式。
val s = person.name ?: return
这些表达式的类型是 Nothing type
Break and Continue Labels
在Kotlin中任何表达式被一个标签标记。标签们的形式是跟有@符号的标识符。例如: abc@
, fooBar@
是合法标签(参看语法).为了标记一个表达式,我们把一个标签放到它前面
loop@ for (i in 1..100) {
// ...
}
现在,我们能够限定一个break或者一个continue通过标签。
loop@ for (i in 1..100) {
for (j in 1..100) {
if (...) break@loop
}
}
在loop进行了标记之后,一个带有标签的中断会跳转到执行点。一个contine处理下一个循环的迭代。
Return at Labels
在Kotlin中,函数使用字面函数,局部函数和对象表达式可以被嵌套。合格的return允许我们从外部函数中返回。最重要的用例是返回一个lambda表达式。回想一下当我们写下这个:
fun foo() {
ints.forEach {
if (it == 0) return
print(it)
}
}
return-expression从他最近的闭包函数当中返回,也就是foo.(注意这种类型的非局部返回仅仅被传入到内联函数的lambda表达式支持)如果我们需要返回一个lambda表达式,我们必须标记它并且使return具有资格
fun foo() {
ints.forEach lit@ {
if (it == 0) return@lit
print(it)
}
}
现在,它仅仅从lambda表达式中返回。通常情况下,使用隐喻标签更方便:这类标签与被传入的lambda表达式的函数有相同的名称。
fun foo() {
ints.forEach {
if (it == 0) return@forEach
print(it)
}
}
同样的,我们可以把lambda表达式替换为一个匿名函数。一个return语句在一个匿名函数中将会从匿名函数本身中返回。
fun foo() {
ints.forEach(fun(value: Int) {
if (value == 0) return
print(value)
})
}
当返回一个值,解析器优先有资格的return,也就是
return@a 1
意味着”返回1 在标签@a”非”返回一个标记的表达式(@a 1)”.