Scala類:復(fù)數(shù)類,無參方法,繼承和覆蓋
本文源自Michel Schinz和Philipp Haller所寫的A Scala Tutorial for Java programmers,由Bearice成中文。***篇為Scala簡單做了一下入門,第二篇描述Scala對象。在這一部分中,將對Scala類進(jìn)行一些介紹。
51CTO編輯推薦:Scala編程語言專題
5 Scala類
正如我們所見,Scala是一門面向?qū)ο蟮恼Z言,因此它擁有很多關(guān)于“類”的描述 。Scala類使用和Java類似的語法進(jìn)行定義。但是一個重要的不同點(diǎn)在于Scala中的類可以擁有參數(shù),這樣就可以得出我們下面關(guān)于對復(fù)數(shù)類(Complex)的定義:
class Complex(real: Double, imaginary: Double) {
def re() = real
def im() = imaginary
}
我們的復(fù)數(shù)類(Complex)接受兩個參數(shù):實(shí)部和虛部。這些參數(shù)必須在實(shí)例化時進(jìn)行傳遞,就像這樣:new Complex(1.5, 2.3)。類定義中包括兩個叫做re和im的方法,分別接受上面提到的兩個參數(shù)。
值得注意的是這兩個方法的返回類型并沒有顯式的聲明出來。他們會被編譯器自動識別。在本例中他們被識別為Double
但是編譯器并不總是像本例中的那樣進(jìn)行自動識別。不幸的是關(guān)于什么時候識別,什么時候不識別的規(guī)則相當(dāng)冗雜。在實(shí)踐中這通常不會成為一個問題,因?yàn)楫?dāng)編譯器處理不了的時候會發(fā)出相當(dāng)?shù)谋г?。作為一個推薦的原則,Scala的新手們通??梢栽囍÷灶愋投x而讓編譯器通過上下文自己判斷。久而久之,新手們就可以感知到什么時候應(yīng)該省略類型,什么時候不應(yīng)該。
5.1 無參方法
關(guān)于方法re和im還有一個小問題:你必須在名字后面加上一對括號來調(diào)用它們。請看下面的例子:
object ComplexNumbers {
def main(args: Array[String]) {
val c = new Complex(1.2, 3.4)
println("imaginary part: " + c.im())
}
}
你可能覺得吧這些函數(shù)當(dāng)作變量使用,而不是當(dāng)作函數(shù)進(jìn)行調(diào)用,可能會更加令人感到舒服。事實(shí)上我們可以通過定義無參函數(shù)在Scala做到這點(diǎn)。這類函數(shù)與其他的具有0個參數(shù)的函數(shù)的不同點(diǎn)在于他們定義時不需要在名字后面加括弧,所以在使用時也不用加(但是無疑的,他們是函數(shù)),因此,我們的Complex類可以重新寫成下面的樣子;
class Complex(real: Double, imaginary: Double) {
def re = real
def im = imaginary
}
5.2 繼承和覆蓋
Scala中的所有類都繼承一個父類,當(dāng)沒有顯示聲明父類時(就像上面定義的Complex一樣),它們的父類隱形指定為scala.AnyRef。
在子類中覆蓋父類的成員是可能的。但是你需要通過override修飾符顯示指定成員的覆蓋。這樣的規(guī)則可以避免意外覆蓋的情況發(fā)生。作為演示,我們在Complex的定義中覆蓋了Object的toString方法。
class Complex(real: Double, imaginary: Double) {
def re = real
def im = imaginary
override def toString() =
"" + re + (if (im < 0) "" else "+") + im + "i"
}
有關(guān)Scala類先介紹到這里,下面將介紹Scala的模式匹配和條件類。
【相關(guān)閱讀】