在kotlin中, 不仅可以对方法重载,还可以对属性重载。在java中,在子类中很少重载父类中的属性,虽然这也是可以的。
比如下边的例子:
open class Apple<T>{
open val info : T?
constructor(){
info = null
}
constructor(info: T){
this.info = info
}
}
class A(info: String): Apple<String>(info){
override val info: String? <<<<<<<<<<
get() = "child info + " + super.info
}
fun main(){
var a = A("supper info")
println(a.info)
}
class A对info进行了重载,但要注意的是在重载时,重写了getter方法,而且没有对info进行初始化。这是因为这种方式的属性重载,实际上是重载了getter方法,在子类中并没有重复声明同名field。这个可以通过多种方式验证,比如查看对应的java代码,或者直接在getter方法中尝试使用field, 编译器会提示子类中该info变量没有对应的backing field。所以针对这种方式的重载就不需要在子类实例初始化重载之后的变量了。
如果写成这样的方式进行重载(官方没有推荐这种做法),那就需要实例化对应的重载属性。
class A(info: String): Apple<String>(info){
override val info: String? = "child info + " + super.info
}