溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Kotlin類與繼承

發(fā)布時(shí)間:2020-07-25 23:34:06 來(lái)源:網(wǎng)絡(luò) 閱讀:621 作者:Mcx陌晨旭 欄目:開發(fā)技術(shù)

Kotlin使用class關(guān)鍵字聲明類,類聲明由類名、類頭(指定其類型參數(shù)、主 構(gòu)造函數(shù)等)和由大括號(hào)包圍的類體組成。

類頭和類體都是可選的,如果一個(gè)類沒有類體大括號(hào)可省略

class NoBody


類的構(gòu)造函數(shù)

一類可以有一個(gè)主構(gòu)造函數(shù)和一個(gè)或多個(gè)次構(gòu)造函數(shù)。主構(gòu)造函數(shù)是類頭的一部分:它跟在類名(和可選的類型參數(shù))后

主構(gòu)造函數(shù)不能包含任何代碼塊,可用init塊初始化代碼,并且可訪問(wèn)主構(gòu)造函數(shù)的參數(shù)

class Person constructor(firstName: String) {
    init {
        println(firstName)
    }
}

如果類頭沒有任何注解或者可見性修飾符,constructor關(guān)鍵字可省略

class Person2(firstName: String) {
    init {
        println(firstName)
    }
}

如果構(gòu)造函數(shù)有注解或可見性修飾符,這個(gè)constructor關(guān)鍵字是必需的,并且這些修飾符在它前面

class Person3 public constructor(firstName: String) {
    init {
        println(firstName)
    }
}


次構(gòu)造函數(shù)

類也可以聲明次構(gòu)造函數(shù)

class Animal {
    constructor(name: String) {
        println(name)
    }
}

如果一個(gè)類有主構(gòu)造函數(shù),每個(gè)次構(gòu)造函數(shù)都需要委托給主構(gòu)造函數(shù),可以直接委托或者通過(guò)其它次構(gòu)造函數(shù)間接委托

使用this關(guān)鍵字直接委托給當(dāng)前類的主構(gòu)造函數(shù)

class Animal2(name: String) {
    constructor(name: String, age: Int) : this(name) {
        println(name + age)
    }

    init {
        println(name)
    }
}

如果一非抽象類沒有任何主或者次構(gòu)造函數(shù),它會(huì)默認(rèn)生成一個(gè)不帶參的主構(gòu)造函數(shù)

class Animal3 {}

等同于

class Animal3(){}

將構(gòu)造函數(shù)用private修飾可以防止被創(chuàng)建類的實(shí)例

class DontCreate private constructor() {}


創(chuàng)建類的實(shí)例

類定義后,需要?jiǎng)?chuàng)建實(shí)例才能使用

fun main(args: Array<String>) {
    //實(shí)例化,Kotlin類的實(shí)例化省去了new關(guān)鍵字
    var person = Person("zhangsna")
    var person1 = Animal3()

    println(person)
    println(person1)

    //private修飾符修飾的構(gòu)造方法不能實(shí)例化
    //var dontCreate = DontCreate()
}


繼承

Kotlin和Java一樣都有隱式繼承,Java中一個(gè)類如果沒有顯示的繼承一個(gè)類默認(rèn)繼承Object

而Kotlin中默認(rèn)繼承Any

class Example  //隱式繼承Any

Any中只有 equals()、hashCode()和toString()三個(gè)方法。附Any類源碼圖

Kotlin類與繼承

在Kotlin中所有的類默認(rèn)為final類型,是不能夠被繼承的。如果該類需要被繼承則必須加上open關(guān)鍵字否則該類編譯成class后是一個(gè)final類

open class Base {
}

使用:符號(hào)實(shí)現(xiàn)繼承,繼承的父類必須初始化

class Car : Base() {
}

如果父類主構(gòu)造函數(shù)有參數(shù)子類必須聲明一個(gè)有參數(shù)的主構(gòu)造函數(shù)初始化父類的構(gòu)造函數(shù)

open class Device(name: String) {
    init {
        println(name)
    }
}

class Phone(name: String) : Device(name) {
}

如果父類沒有主構(gòu)造函數(shù),那么子類每個(gè)次構(gòu)造函數(shù)都必須使用super關(guān)鍵字調(diào)初始化父類次構(gòu)造函數(shù)

open class Device2 {
    constructor(name: String) {
        println(name)
    }

    constructor(type: Int, weight: Int) {
        println("$type" + weight)
    }
}

class Computor : Device2 {
    constructor(name: String) : super(name)
    constructor(type: Int, weight: Int) : super(type, weight)
}


覆蓋方法和屬性

Kotlin中需要overried關(guān)鍵字顯示的覆蓋成員

open class Father {
    open var a: Int = 1
    open fun say() {
        println("father say")
    }
}

class Son : Father() {
    //必須加上overried關(guān)鍵字,覆蓋父類成員
    override var a: Int = 2

    override fun say() {
        println("son say")
    }
}


抽象類和繼承

使用abstract關(guān)鍵字定義抽象類

abstract class Abstract {
    //定義抽象方法時(shí),必能有方法體
    abstract fun absFun()
}
class Sub : Abstract() {
    //子類必須實(shí)現(xiàn)父類的抽象方法
    override fun absFun() {
        println("absFun of sub")
    }
}


向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI