之前用過scala中的伴生對(duì)象,隔一段時(shí)間不用又有點(diǎn)忘記掉了。特此記錄,方便后續(xù)查找。
成都創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站建設(shè)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的山海關(guān)網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!1.伴生對(duì)象語法class MyClass {
def printname() = {
println(s"myname is: ${MyClass.name}")
}
}
object MyClass {
private val name="xlili"
private val age=10;
def printStaticMethod() = {
println("static method don't need instantiate!")
}
}
在同一個(gè)文件中,有如上的代碼,代碼包含有MyClass類與MyClass對(duì)象。如果在同一文件中同時(shí)有class xxx與object xxx時(shí),
class xxx被稱為object xxx的伴生類
object xxx被稱為class xxx的伴生對(duì)象
需要注意的是,class xxx與object xxx中的xxx名字要相同。
編譯完成以后,伴生類class xxx編譯結(jié)果為xxx.class,而伴生對(duì)象object xxx編譯結(jié)果為x$.class
3.伴生對(duì)象的作用大家肯定都會(huì)問,為什么需要伴生對(duì)象?
伴生對(duì)象存在的價(jià)值,就是因?yàn)閟cala中沒有static關(guān)鍵字,可以解決scala中實(shí)現(xiàn)類似Java中的類,在一個(gè)類里面既有實(shí)例成員變量,又有靜態(tài)變量。
同時(shí),伴生類與伴生對(duì)象中的private屬性,還可以相互訪問。
def ttt() = {
val obj = new MyClass
obj.printname()
MyClass.printStaticMethod()
}
上面的代碼運(yùn)行結(jié)果為:
myname is: xlili
static method don't need instantiate!
上面的例子就說明了以上兩點(diǎn):
1.伴生類與伴生對(duì)象可以相互訪問各自私有屬性。
2.伴生對(duì)象中的方法可以用類名直接調(diào)用,相當(dāng)于實(shí)現(xiàn)了Java中的static方法。
case class與普通class的區(qū)別主要有
1.case class中的每個(gè)參數(shù)都以val的形式存在,除非顯式聲明為var
2.case class自動(dòng)生成伴生對(duì)象,且伴生對(duì)象中會(huì)自動(dòng)生成apply方法,因此case class可以直接用類名生成對(duì)象而省略new關(guān)鍵字。
3.case class中的伴生對(duì)象還會(huì)自動(dòng)生成unapply方法,unapply方法會(huì)提取主構(gòu)造器的參數(shù)進(jìn)行模式匹配。
4.自動(dòng)產(chǎn)生copy方法,來構(gòu)建一個(gè)與現(xiàn)有值相同的新對(duì)象
5.case class中自動(dòng)產(chǎn)生hashcode,toString,equals等方法
當(dāng)case class的父類使用關(guān)鍵字sealed修飾的時(shí)候,編譯器會(huì)校驗(yàn)對(duì)該超類對(duì)象的模式匹配規(guī)則中,是否列出了全部可能的子case類??匆粋€(gè)具體實(shí)例
sealed abstract class PClass
case class S1(name: String) extends PClass
case class S2(name: String) extends PClass
case class S3(name: String) extends PClass
def t1() = {
val p: PClass = S2("xxx")
p match {
case S1(_) =>println("I'm S1!")
case S2(_) =>println("I'm S2!")
}
}
上面的代碼,編譯器就會(huì)發(fā)出警告,因?yàn)闆]有對(duì)S3進(jìn)行模式匹配,所以會(huì)出問題。
當(dāng)然解決的方法,就是加上對(duì)S3的模式匹配。
所以,使用 sealed 修飾某個(gè) class 的目的是讓 Scala 知道所有 case 的情況,否則會(huì)編譯報(bào)錯(cuò)。
當(dāng)然我們還可以作弊,使用 @unchecked 告訴編譯器可以不用檢查也能編譯通過。
當(dāng)使用 sealed 來修飾某個(gè) class 時(shí),注意繼承該類的其他子類需要跟父類在同一文件中。
你是否還在尋找穩(wěn)定的海外服務(wù)器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機(jī)房具備T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確流量調(diào)度確保服務(wù)器高可用性,企業(yè)級(jí)服務(wù)器適合批量采購,新人活動(dòng)首月15元起,快前往官網(wǎng)查看詳情吧