Kotlin的流程控制

  • 2019 年 10 月 4 日
  • 筆記

1 when

when就是传统的switch表达的变种

fun cas(obj: Any) {      when (obj) {          1 -> println("One")          "Hello" -> println("Greeting")          is Long -> println("Long")          !is String -> println("not a string")          else -> println("Unknown")      }  }

when表达式

fun whenExpression(obj: Any) {      var result = when (obj) {          is String -> obj.toString()          else -> "Hello"      }  }

总结起来就是

Loops

for

val cakes = listOf<String>("A", "B", "C")      for (cake in cakes) {          println("Yum, it is nice $cake cake!")      }

while do-while

var index = 5      while (index < 10) {          index++      }      do {          println(index--)      } while (index > 0)

对于loop下的几种方式有编程基础的混个脸熟带过就行

Ranges

for(i in 0..3) {             // 1      print(i)  }  print(" ")    for(i in 2..8 step 2) {      // 2      print(i)  }  print(" ")    for (i in 3 downTo 0) {      // 3      print(i)  }  print(" ")

range也是一个基础语法方式,表示一个数据范围如 1..3

我们除了遍历也可以用于判断是否存在这个范围内

if (x !in 1..4) {            // 2      print(x)  }

上面是判断x是否在1..4这个range中

Equals的判断

在kt中有==和===,但是无论哪个必须是同类才可

不同之处在于==还判断内部元素而===更多的是判断地址是否相同

看下面两个例子

val authors = setOf("Shakespeare", "Hemingway", "Twain")  val writers = setOf("Twain", "Shakespeare", "Hemingway")    println(authors == writers)   // 1  println(authors === writers)  // 2

上栗1的结果为true,2的结果为false,因为1是将内部数据排序然后比较数据,而2则是因为两个地址不同直接判断为false。我们再看下里

val authors = setOf("Shakespeare", "Hemingway", "Twain")  val writers = authors    println(authors == writers)   // 1  println(authors === writers)  // 2

根据上面的原理俩个的结果可定都是true

最后就是 典型的三目?表达式

fun max(a: Int, b: Int) = if (a > b) a else b         // 1    println(max(99, -42))