- 标签
在Kt中任何表达式都可以用标签label来标记。标签的格式为标识符后跟@符号,例如: adc@、jarOfLove@都是有效的标签。我们可以用Label标签来控制return、break或continue的跳转行为。
Kt的函数是可以被嵌套的。它有函数字面量、局部函数等。有了标签限制return,我们就可以从外层行数返回了。
第一个例子是显示标签,我们明确指定lambda表达式中的return地址是其入口处。
fun returnDemo1(){
println("START : "+::returnDemo1.name)
val intArray = intArrayOf(1,2,3,4,5,6,7)
intArray.forEach {
if (it == 3) return
println(it)
}
println(" END : "+::returnDemo1.name)//正常遍历,输出结果只有1和2
}
fun returnDemo2(){
println("START : "+::returnDemo2.name)
val intArray = intArrayOf(1,2,3,4,5,6,7)
intArray.forEach here@{
if (it == 3) return@here//指令跳转到lambda表达式标签here@处。
println(it) //继续下一个it = 4遍历循环
}
println(" END : "+::returnDemo2.name)//结果1、2、4、5、6、7
}
我们在lambda表达式开头处添加了here@标签,该标签相当于是记录了lambda表达式的指令入口地址。然后通过@here表达式跳转到lambda表达式该地址。
第二个例子,我们也可以采用隐式的标签,所谓的隐式标签就是该标签与接收该lambda的函数同名。
fun returnDemo3(){
println("START : "+::returnDemo3.name)
val intArray = intArrayOf(1,2,3,4,5,6,7)
intArray.forEach {
if (it == 3) return@forEach//从lambda表达式@forEach中返回。
println(it)
}
println(" END : "+::returnDemo3.name)//结果1、2、4、5、6、7
}
break循环使用
fun breakDemo2(){
println("START : "+::breakDemo2.name)
outer@ for ( out in 1..5){
println("outer $out")
for (inner in 1..5){
if(inner % 2 == 0){
break@outer
}
println("inner $inner")
}
}
println(" END : "+::breakDemo2.name)
}
其实与原来的写法很相似,但是用在比较复杂的方法里面用标签比较方便。