kotlin

11. Kotlin继承

2017-11-08  本文已影响113人  厚土火焱

Kotlin中所有的类都继承自 Any 类。Any 是所有类的超类。
Any提供了三个函数
equals()、hashCode()、toString()
一个类如果希望被别的类继承,可以使用 open 关键字进行修饰。

open class Base(p: Int)
class Derived(p: Int) : Base(p)

有主构造函数的子类

子类有主构造函数的,基类在主构造函数中初始化。

package main

fun main(args: Array<String>) {
    val s = Student("金龙翼", 27, "A737509111722", 100)
    println("学生姓名:${s.name}")
    println("年龄:${s.age}")
    println("学号:${s.no}")
    println("成绩:${s.score}")
}

open class Person(var name: String, var age: Int){
    //基类
}

class Student(name: String, age: Int, var no: String, var score: Int): Person(name, age){

}

运行结果

学生姓名:金龙翼
年龄:27
学号:A737509111722
成绩:100

子类没有主构造函数时,必须在每一个二级构造函数中用 super 关键字初始化基类,或者在代理另一个构造函数。初始化基类时,可以调用基类的不同构造方法。
子类和基类

open class Person2(name: String){
    constructor(name: String, age: Int): this(name){
        //基类次级构造
        println("-----------基类次级构造函数-------------")
    }
}
class Student2:Person2{
    constructor(name: String, age: Int, no: String, store: Int): super(name, age){
        println("----------继承类次级构造函数------------")
        println("学生姓名:${name}")
        println("年龄:${age}")
        println("学号:${no}")
        println("成绩:${store}")
    }
}

主函数中直接实例化

var ss = Student2("天龙", 25, "B90161015", 120)

看运行结果

-----------基类次级构造函数-------------
----------继承类次级构造函数------------
学生姓名:天龙
年龄:25
学号:B90161015
成绩:120
重写

当我们写一个 fun 函数时,此函数默认为 final 修饰。当我们需要允许子类重写该函数的,需要手动添加 open 修饰它。子类重写方法使用 override 关键字。

package main

fun main(args: Array<String>) {
    val s = Student()
    s.study()
}

open class Person{
    open fun study(){
        println("我毕业了")
    }
}

open class Student: Person(){
    override fun study() {
        println("我在读大学")
    }
}

运行这段代码,就会发现,输出的是

我在读大学

呵呵,当然我没在读大学了。只是,这里用重写 override fun study() 替换了基类内的 open fun study() 执行。
这只是继承了一个类,如果子类继承了类同时还有接口,并且这些类和接口还有相同的函数方法,子类必须要重写该函数方法,使用 super 泛型选择性地调用父类的实现。

package main

fun main(args: Array<String>) {
    val s = Student()
    s.study()

    val c = C()
    c.f()

    val d = D()
    d.f()
}

open class Person{
    open fun study(){
        println("我毕业了")
    }
}

open class Student: Person(){
    override fun study() {
        println("我在读大学")
    }
}

open class A{
    open fun f(){
        println("A")
    }
    fun a(){
        println("a")
    }
}
interface B{
    fun f(){
        println("B")
    }
    fun b(){
        println("b")
    }
}
open class DD{
    open fun f(){
        println("DD")
    }
    fun dd(){
        println("dd")
    }
}
class C(): A(), B{
    override fun f() {
        super<A>.f()
        super<B>.f()
    }
}
class D(): DD(), B{
    override fun f() {
        super<B>.f()
        super<DD>.f()
    }
}

运行结果

A
B
B
DD
属性重写

属性重写也需要用到 override ,属性必须具有兼容类型,每个声明的属性都可以通过初始化程序或者 getter 方法被重写。

package main

fun main(args: Array<String>) {
    var s = Student()
    println(s.name)

    var b = Bar2()
    println(b.x)
}

interface Foo{
    val x:Int
}

class Bar1(override val x: Int):Foo

class Bar2 : Foo{
    override var x: Int = 0
}


open class Person{
    open val name: String = "Joel"
}

class Student:Person(){
    override var name = "Cofox"
}

运行结果

Cofox
0
上一篇下一篇

猜你喜欢

热点阅读