說明
Kotlin中的接口與Java8非常相似。他們可以包含抽象方法的聲明,以及方法實(shí)現(xiàn)。與抽象類不同,接口不能存在存儲(chǔ)狀態(tài)。他們可以具有屬性,但這些屬性必須是抽象的,或者提供存儲(chǔ)器實(shí)現(xiàn)。
舉例
定義接口
接口聲明
與Java類似,在kotlin中使用關(guān)鍵字interface聲明接口
interface MyInterface
{
fun bar()// 未實(shí)現(xiàn)
fun foo()
{? //已實(shí)現(xiàn)
// 可選的方法體
println("foo")
}
}
實(shí)現(xiàn)接口
一個(gè)類或者對(duì)象可以實(shí)現(xiàn)一個(gè)或多個(gè)接口,類和接口之間使用運(yùn)算符":"標(biāo)注。
class Child : MyInterface
{
override fun bar()
{
// 方法體
}
}
示例
interface MyInterface
{
fun bar()
fun foo()
{
// 可選的方法體
println("foo")
}
}
class Child : MyInterface
{
override fun bar()
{
// 方法體
println("bar")
}
}
fun main(args: Array)
{
val c =? Child()
c.foo();
c.bar();
}
輸出結(jié)果:
foo
bar
接口中的屬性
接口中的屬性只能是抽象的,不允許初始化值,接口不會(huì)保存屬性值,實(shí)現(xiàn)接口時(shí),必須重寫屬性。
接口中的屬性
interface MyInterface
{
var name:String //name 屬性, 抽象的
}
創(chuàng)建類實(shí)例重寫接口屬性
class MyImpl:MyInterface
{
override var name: String = "runoob" //重載屬性
}
實(shí)例分析
interface MyInterface
{
var name:String //name 屬性, 抽象的
fun bar()
fun foo()
{
// 可選的方法體
println("foo")
}
}
class Child : MyInterface
{
override var name: String = "runoob" //重載屬性
override fun bar()
{
// 方法體
println("bar")
}
}
fun main(args: Array)
{
val c =? Child()
c.foo();
c.bar();
println(c.name)
}
輸出結(jié)果:
foo
bar
runoob
函數(shù)重寫
實(shí)現(xiàn)多個(gè)接口時(shí),可能會(huì)遇到同一個(gè)方法繼承多個(gè)實(shí)現(xiàn)的問題。
interface A
{
fun foo() { print("A") }// 已實(shí)現(xiàn)
fun bar() // 未實(shí)現(xiàn),沒有方法體,是抽象的
}
interface B
{
fun foo() { print("B") }// 已實(shí)現(xiàn)
fun bar() { print("bar")} // 已實(shí)現(xiàn)
}
class C : A
{
override fun bar() { print("bar") }// 重寫
}
class D : A, B
{
override fun foo()
{
super.foo()
super.foo()
}
override fun bar()
{
super.bar()
}
}
fun main(args: Array)
{
val d =? D()
d.foo();
d.bar();
}
輸出結(jié)果: ABbar
實(shí)例中接口 A 和 B 都定義了方法 foo() 和 bar(), 兩者都實(shí)現(xiàn)了 foo(), B 實(shí)現(xiàn)了 bar()。因?yàn)?C 是一個(gè)實(shí)現(xiàn)了 A 的具體類,所以必須要重寫 bar() 并實(shí)現(xiàn)這個(gè)抽象方法。
然而,如果我們從 A 和 B 派生 D,我們需要實(shí)現(xiàn)多個(gè)接口繼承的所有方法,并指明 D 應(yīng)該如何實(shí)現(xiàn)它們。這一規(guī)則 既適用于繼承單個(gè)實(shí)現(xiàn)(bar())的方法也適用于繼承多個(gè)實(shí)現(xiàn)(foo())的方法。
參考: