When 表达式
when 取代了类 C 语言的 switch 操作符。其最简单的形式如下:
控制流
when (x) {
1 -> print("x == 1")
2 -> print("x == 2")
else -> { // 注意这个块
print("x is neither 1 nor 2")
}
}
when 将它的参数和所有的分支条件顺序比较,直到某个分支满足条件。 when 既可以被当
做表达式使用也可以被当做语句使用。如果它被当做表达式, 符合条件的分支的值就是整个
表达式的值,如果当做语句使用, 则忽略个别分支的值。(像 if 一样,每一个分支可以是
一个代码块,它的值 是块中最后的表达式的值。)
如果其他分支都不满足条件将会求值 else 分支。 如果 when 作为一个表达式使用,则必须
有 else 分支, 除非编译器能够检测出所有的可能情况都已经覆盖了。
如果很多分支需要用相同的方式处理,则可以把多个分支条件放在一起,用逗号分隔:
when (x) {
0, 1 -> print("x == 0 or x == 1")
else -> print("otherwise")
}
我们可以用任意表达式(而不只是常量) 作为分支条件
when (x) {
parseInt(s) -> print("s encodes x")
else -> print("s does not encode x")
}
我们也可以检测一个值在(in ) 或者不在(!in ) 一个区间或者集合中:
when (x) {
in 1..10 -> print("x is in the range")
in validNumbers -> print("x is valid")
!in 10..20 -> print("x is outside the range")
else -> print("none of the above")
}
另一种可能性是检测一个值是(is ) 或者不是(!is ) 一个特定类型的值。注意: 由于智
能转换,你可以访问该类型的方法和属性而无需 任何额外的检测。
控制流
63val hasPrefix = when(x) {
is String -> x.startsWith("prefix")
else -> false
}
when 也可以用来取代 if - else if 链。 如果不提供参数,所有的分支条件都是简单的布
尔表达式,而当一个分支的条件为真时则执行该分支:
when {
x.isOdd() -> print("x is odd")
x.isEven() -> print("x is even")
else -> print("x is funny")
}

最新文章

  1. bzoj3123: [Sdoi2013]森林
  2. 【POJ 1390】Blocks
  3. SAM4E单片机之旅——17、通过UART进行标准IO
  4. swift与OC混编高级教程之混编框架的创建和调用
  5. Routed Events【pluralsight】
  6. poj1947Rebuilding Roads(树形DP)
  7. Zend框架2入门(一) (转)
  8. 提高你开发效率的十五个Visual Studio 2010使用技巧
  9. Android采取async框架文件上传
  10. 【分享】SAS统计分析软件学习教程电子书合集下载
  11. P3003 [USACO10DEC]苹果交货Apple Delivery
  12. Linux 下Beanstalk安装
  13. R语言︱分布函数与概率密度+随机数产生
  14. eclispe 导入android或者java项目出现中文乱码
  15. 【Teradata System】How Teradata uses MPP Systems
  16. DataGrid 查出一个列 按要求显示格式 例如:操作人(地点)
  17. ecna2017-Sheba’s Amoebas
  18. u-boot移植(八)---代码修改---存储控制器--MMU
  19. angular 表单元素的使用总结
  20. f5时间设置

热门文章

  1. Java高并发程序设计学习笔记(七):并行设计模式
  2. java反射浅谈 part1--反射机制的定义,作用,原理
  3. Nginx作为代理服务之正反代理
  4. 如何在cmd命令行中运行Java程序
  5. mtd介绍
  6. SQL语句复习【专题八】
  7. gyp ERR! stack Error: EACCES: permission denied, mkdir问题解决方案
  8. Linux下周期性查看GPU状态
  9. sql 178. 分数排名
  10. 浅入深出Vue:文章编辑