Kotlin 标签@使用

  1. 标签
    在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)
    }

其实与原来的写法很相似,但是用在比较复杂的方法里面用标签比较方便。

你可能感兴趣的:(Kotlin 标签@使用)