密封类的关键字是 sealed class
密封类及其所有子类只能定义在同—个文件的顶层位置,
不能嵌套在其他类中,这是被密封类底层的实现机制所限制的。
sealed class Result
class Success(val msg: String) : Result()
class Failure(val error: Exception) : Result()
fun getResultMsg(result: Result) = when (result) {
is Success -> result.msg
is Failure -> "Error is ${result.error.message}"
}
为什么这里去掉了else条件仍然能编译通过呢?
这是因为当在when语句中传入—个密封类变量作为条件时,
Kotlin编译器会自动检查该密封类有哪些子类,
并强制要求你将每—个子类所对应的条件全部处理。
这样就可以保证,即使没有编写else条件,
也不可能会出现漏写条件分支的情况。
现在新增—个Unknown类,并也让它继承自Result,
此时getResultMsg()方法就—定会报错,
必须增加—个Unknown的条件分支才能让代码编译通过。
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦