Effective Java 第16條: 復(fù)合優(yōu)先于繼承

繼承(inheritance) 是實(shí)現(xiàn)代碼重用的有力手段,但它并非永遠(yuǎn)是完成這項(xiàng)工作的最佳工具.

在包的內(nèi)部使用繼承是非常安全的.然而,對(duì)于普通的具體類進(jìn)行跨越包邊界的繼承,則是非常危險(xiǎn)的.

與方法調(diào)用不同的是,繼承打破了封裝性.

  • 子類依賴于其超類中特定功能的實(shí)現(xiàn)細(xì)節(jié).
  • 超類在后續(xù)的版本中可以獲得新的方法.

避免上述問題: 不用擴(kuò)展現(xiàn)有的類,而是在新的類中新增一個(gè)私有域,它引用現(xiàn)有類的一個(gè)實(shí)例. 這種設(shè)計(jì)被稱為"復(fù)合"(composition)
這樣得到的類會(huì)非常穩(wěn)固,它不依賴于現(xiàn)有類的實(shí)現(xiàn)細(xì)節(jié),即使現(xiàn)有的類添加了新的方法,也不會(huì)影響新的類.

只有當(dāng)子類真正是超類的子類型時(shí), 才適合繼承.
也就是對(duì)于兩個(gè)類A和B, 只有當(dāng)兩者之間確實(shí)存在"is-a"關(guān)系的時(shí)候,類B才應(yīng)該擴(kuò)展A.

簡(jiǎn)而言之, 繼承的功能非常強(qiáng)大,但是也存在諸多問題,因?yàn)樗`背了封裝原則.只有當(dāng)子類和超類之間確實(shí)存在子類型關(guān)系時(shí),使用繼承才是恰當(dāng)?shù)? 即便如此, 如果子類和超類處在不同的包中, 并且超類并不是為了繼承而設(shè)計(jì)的, 那么繼承將會(huì)導(dǎo)致脆弱性. 為了避免這種脆弱性, 可以用復(fù)合和轉(zhuǎn)發(fā)機(jī)制來代替繼承,尤其是當(dāng)存在適當(dāng)?shù)慕涌诳梢詫?shí)現(xiàn)包裝類的時(shí)候. 包裝類不僅比子類更加健壯, 而且功能也更加強(qiáng)大.

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容