Kotlin密封类

Kotlin密封类

密封类被用于展示受限的类层次结构。当一个值可以有一个来自一个有限集合中的类型,但不能有任何其他类型。在某种程度上来说,它们是枚举类的扩展,一个枚举类型的值的集合也是受限的。但每一个枚举常量只作为一个单例存在,而密封类的子类可以有多个实例,这些实例都可以包含状态。
定义一个密封类,你只需将sealed修饰符放在类名之前。一个密封类可以有多个子类,但它们必须和密封类定义在同一个文件中。

sealed class Expr
data class Const(val number: Double) : Expr()
data class Sum(val e1: Expr, val e2: Expr) : Expr()
object NotANumber : Expr()

其中Const和Sum可以被继承, NotANumber实际上是一个单例。
(1)sealed class所有的子类必须和sealed class在同一个文件声明. (注意如果是子类的子类(间接继承), 则可以在任何地方.)
(2)sealed class本身是抽象的, 不能被直接实例化, 可以有abstract成员.
(3)密封类的构造函数默认是private的,密封类不允许有非private构造函数。
注意,扩展密封类的子类(间接继承器)的类可以放置在任何地方,不一定在同一个文件中。
sealed class常用在when表达式中,如果所有情形都覆盖到了, 可以省略else。当你在when表达式使用密封类,使用密封类的好处就发挥作用了。但是,只有将when用作表达式时,这才有效,而不是作为一个声明。

fun eval(expr: Expr): Double = when(expr) {
	is Const -> expr.number
	is Sum -> eval(expr.e1) + eval(expr.e2)
	NotANumber -> Double.NaN
	// 不需要else语句,因为我们已涵盖所有情况
}

用when表达式时, 如果有分支没有被覆盖到, 并且没有提供else, 编译会有错误提示的。

完整的例子:

sealed class Expr
data class Const(val number: Double) : Expr()
data class Sum(val e1: Expr, val e2: Expr) : Expr()
object NotANumber : Expr()

fun eval(expr: Expr): Double = when(expr) {
    is Const -> expr.number
    is Sum -> eval(expr.e1) + eval(expr.e2)
    NotANumber -> Double.NaN
}

fun main(args:Array<String>){
	val const = Const(100.0)
        Log.i("RS"," "+eval(const))
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值