IT培訓(xùn)網(wǎng)
IT在線學(xué)習(xí)
一、抽象類
abstract 修飾的類就是抽象類。Scala中的抽象類類似于Java中的抽象類,不能實(shí)例化。但應(yīng)該知道的是抽象類中同樣有構(gòu)造器。
抽象類中可以有抽象方法和普通方法。當(dāng)然也可以只有普通方法(當(dāng)然這種情況相對(duì)少一些),只需要在class前面加上abstract關(guān)鍵字,此類便是抽象類。但是另一方面,有抽象方法的類則一定要定義成抽象類了。
抽象方法前面不需加abstract關(guān)鍵字,沒有方法體的方法的便是抽象方法了,這一點(diǎn)跟Java中的不太一樣。
abstract class Animal(val age: Int) {
// 抽象方法
def eat()
// 普通的方法
def sleep(sound: String) = {
println(s"sleep with $sound")
}
}
object TestAnimal{
def main(args: Array[String]): Unit = {
// 實(shí)現(xiàn)類
val a1 = new Animal(2) {
override def eat(): Unit = {
println("animal eats...")
}
}
a1.eat()
a1.sleep("huhuhu...")
}
}
上例中的Animal就是一個(gè)抽象類,里面有一個(gè)抽象方法:def eat()。在TestAnimal中使用了一個(gè)匿名內(nèi)部類實(shí)現(xiàn)了eat方法。所以,我們?cè)赥estAnimal中的既可以調(diào)用Animal中的普通方法,也可以調(diào)用被實(shí)現(xiàn)的抽象方法eat方法。
二、特質(zhì)(Trait)
Scala中特質(zhì)Trait類似于Java中的接口,但是功能更強(qiáng)大。
Java中接口的使用,是通過(guò)類來(lái)實(shí)現(xiàn)接口,使用的關(guān)鍵字是implements。
Scala中類不是實(shí)現(xiàn)特質(zhì),而是混入特質(zhì),使用的關(guān)鍵字是extends或with。
Jdk1.8之前的接口中,不能寫具體的方法,jdk1.8+ 支持在接口中寫具體的方法。Scala中的特質(zhì)是可以寫具體方法的。當(dāng)然跟接口一樣,特質(zhì)是沒有構(gòu)造器的。
trait Runnable{
def run()={
println("run....")
}
}
trait Flyable{
def fly()
}
class Bird extends Runnable with Flyable {
override def run(): Unit = {
println("run run run ...")
}
def fly(): Unit = {
println("fly...")
}
}
object TestBird{
def main(args: Array[String]): Unit = {
val bird=new Bird()
bird.fly()
bird.run()
}
}
在上面的例子中,我們定義了兩個(gè)特質(zhì)。為了驗(yàn)證,特質(zhì)Runnable中,只有一個(gè)普通方法,特質(zhì)Flyable中只有一個(gè)抽象方法。Bird混入了兩個(gè)特質(zhì),我們要注意到使用的關(guān)鍵字的不同,如果此類沒有繼承其他的類,則混入的第一個(gè)特質(zhì)使用extends關(guān)鍵字,從第二個(gè)開始使用with關(guān)鍵字。
另外一點(diǎn)要說(shuō)明的是override關(guān)鍵字。如果重寫的是普通方法,則必須加上override關(guān)鍵字;如果重寫的是抽象方法,可以省略override關(guān)鍵字。
>>本文地址:http://www.littlerockbway.com/zhuanye/2021/69761.html
聲明:本站稿件版權(quán)均屬中公教育優(yōu)就業(yè)所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
1 您的年齡
2 您的學(xué)歷
3 您更想做哪個(gè)方向的工作?