




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、合成/聚合復(fù)用原則(Composite/Aggregate Reuse Principle,CARP)合成(Composition)和聚合(Aggregation)都是關(guān)聯(lián)(Association)的特殊種類。聚合表示整體和部分的關(guān)系,表示“擁有”。如奔馳S360汽車,對奔馳S360引擎、奔馳S360輪胎的關(guān)系是聚合關(guān)系,離開了奔馳S360汽車,引擎、輪胎就失去了存在的意義。在設(shè)計(jì)中,聚合不應(yīng)該頻繁出現(xiàn),這樣會增大設(shè)計(jì)的耦合度。合成則是一種更強(qiáng)的“擁有”,部分和整體的生命周期一樣。合成的新的對象完全支配其組成部分,包括它們的創(chuàng)建和湮滅等。一個(gè)合成關(guān)系的成分對象是不能與另一個(gè)合成關(guān)系共享的。
2、160; 換句話說,合成是值的聚合(Aggregation by Value),而一般說的聚合是引用的聚合(Aggregation by Reference)。在面向?qū)ο笤O(shè)計(jì)中,有兩種基本的辦法可以實(shí)現(xiàn)復(fù)用:第一種是通過合成/聚合,即合成復(fù)用原則,含義是指,盡量使用合成/聚合,而不是使用繼承。第二種就是通過繼承。要正確地選擇合成/復(fù)用和繼承的方法是,只有當(dāng)以下的條件全部被滿足時(shí),才應(yīng)當(dāng)使用繼承關(guān)系:1)子類是父類的一個(gè)特殊種類,而不是父類的一個(gè)角色,也就是區(qū)分"Has-A"和"Is-A"。只有"Is-A"關(guān)系才
3、符合繼承關(guān)系,"Has-A"關(guān)系應(yīng)當(dāng)用聚合來描述。2)永遠(yuǎn)不會出現(xiàn)需要將子類換成另外一個(gè)類的子類的情況。如果不能肯定將來是否會變成另外一個(gè)子類的話,就不要使用繼承。3)子類具有擴(kuò)展父類的責(zé)任,而不是具有置換掉(override)或注銷掉(Nullify)父類的責(zé)任。如果一個(gè)子類需要大量的置換掉父類的行為,那么這個(gè)類就不應(yīng)該是這個(gè)父類的子類。4)只有在分類學(xué)角度上有意義時(shí),才可以使用繼承。如果語義上存在著明確的is-a關(guān)系,并且這種關(guān)系是穩(wěn)定的、不變的,則考慮使用繼承;如果沒有is-a關(guān)系,或者這種關(guān)系是可變的,使用合成。錯(cuò)誤的使用繼承而不是合成 / 聚合的一個(gè)常見原因是錯(cuò)誤
4、的把 “Has-A” 當(dāng)成了 “Is A” 。 “Is A” 代表一個(gè)類是另外一個(gè)類的一種; “Has-A” 代表一個(gè)類是另外一個(gè)類的一個(gè)角色,而不是另外一個(gè)類的特殊種類。 我們看一個(gè)例子。如果我們把 “ 人 ” 當(dāng)成一個(gè)類,然后把 “ 雇員 ” , “ 經(jīng)理 ” , “ 學(xué)生 ” 當(dāng)成是 “ 人 ” 的子類。這個(gè)的錯(cuò)誤在于把 “ 角色 ” 的等級結(jié)構(gòu)和 “ 人 ” 的等級結(jié)構(gòu)混淆了。 “ 經(jīng)理 ” , “ 雇員 ” , “ 學(xué)生 ” 是一個(gè)人的角色,一個(gè)人可以同時(shí)擁有上述角色。如果按繼承來設(shè)計(jì),那么如果一個(gè)人是雇員的話,就不可能是學(xué)生,這顯然不合理。正確的設(shè)計(jì)是有個(gè)抽象類 “ 角色 ” ,
5、“ 人 ” 可以擁有多個(gè) “ 角色 ” (聚合), “ 雇員 ” , “ 經(jīng)理 ” , “ 學(xué)生 ” 是 “ 角色 ” 的子類。 另外一個(gè)就是只有兩個(gè)類滿足里氏替換原則的時(shí)候,才可能是 “Is A” 關(guān)系。也就是說,如果兩個(gè)類是 “Has-A” 關(guān)系,但是設(shè)計(jì)成了繼承,那么肯定違反里氏替換原則。通過合成/聚合的優(yōu)缺點(diǎn)優(yōu)點(diǎn):1) 新對象存取子對象的唯一方法是通過子對象的接口。2) 這種復(fù)用是黑箱復(fù)用,因?yàn)樽訉ο蟮膬?nèi)部細(xì)節(jié)是新對象所看不見的。3) 這種復(fù)用更好地支持封裝性。4) 這種復(fù)用實(shí)現(xiàn)上的相互依賴性比較小。5) 每一個(gè)新的類可以將焦點(diǎn)集中在一個(gè)任務(wù)上。6) 這種復(fù)用可以在運(yùn)行時(shí)間內(nèi)動態(tài)進(jìn)行,新對象可以動態(tài)的引用與子對象類型相同的對象。7) 作為復(fù)用手段可以應(yīng)用到幾乎任何環(huán)境中去。缺點(diǎn): 就是系統(tǒng)中會有較多的對象需要管理。4.4 通過繼承來進(jìn)行復(fù)用的優(yōu)缺點(diǎn)優(yōu)點(diǎn):新的實(shí)現(xiàn)較為容易,因?yàn)楦割惖拇蟛糠止δ芸梢酝ㄟ^繼承的關(guān)系自動進(jìn)入子類。修改和擴(kuò)展繼承而來的實(shí)現(xiàn)較為容易。 缺點(diǎn):繼承復(fù)用破壞封裝性,因?yàn)槔^承將父類的實(shí)現(xiàn)細(xì)節(jié)暴露給子類。由于父類的內(nèi)部細(xì)節(jié)常常是對于子
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年中國微機(jī)型線路保護(hù)裝置市場調(diào)查研究報(bào)告
- 2025年中國彩印塑料薄膜市場調(diào)查研究報(bào)告
- CAD考試中的技術(shù)拓展與學(xué)用結(jié)合分析試題及答案
- 2025年中國異型電鍍磨輪市場調(diào)查研究報(bào)告
- 2025年中國康佳鼓一托二架數(shù)據(jù)監(jiān)測研究報(bào)告
- 2025年中國干部檔案名冊數(shù)據(jù)監(jiān)測研究報(bào)告
- 2025年中國巧克力硬質(zhì)糖數(shù)據(jù)監(jiān)測研究報(bào)告
- 2025年中國工業(yè)訊號轉(zhuǎn)換器數(shù)據(jù)監(jiān)測研究報(bào)告
- 2025年中國嵌入式可讀寫器板市場調(diào)查研究報(bào)告
- 2025年中國尼龍光纜雙保險(xiǎn)滑車市場調(diào)查研究報(bào)告
- 科室病歷書寫與管理制度
- 地震監(jiān)測系統(tǒng)服務(wù)方案及故障維修處理措施
- 新工會制度財(cái)務(wù)知識大賽題庫(預(yù)算、決算部分)
- 《交通事故車輛及財(cái)物損失價(jià)格鑒證評估技術(shù)規(guī)范》
- 以茶為媒的小學(xué)跨學(xué)科教育研究
- 電力設(shè)備交接和預(yù)防性試驗(yàn)規(guī)程
- 2024年度高速公路機(jī)電設(shè)備維護(hù)合同:某機(jī)電公司負(fù)責(zé)某段高速公路的機(jī)電設(shè)備維護(hù)2篇
- 中考道德與法治復(fù)習(xí)題型專項(xiàng)漫畫式課件
- 面點(diǎn)師招聘面試題與參考回答(某大型國企)
- 教育部《中小學(xué)德育工作指南》-德育工作指南
- DB21-T 2885-2023 居住建筑節(jié)能設(shè)計(jì)標(biāo)準(zhǔn)
評論
0/150
提交評論