有時(shí)候我們需要維護(hù)一些對(duì)象,這些對(duì)象具有一定的層次結(jié)構(gòu),它們之間雖然差異很大,但在使用的時(shí)候我們希望能構(gòu)一致的對(duì)待,比如Windows控件,繪圖中的圖形等,這個(gè)時(shí)候我們就可以采用組合模式來(lái)進(jìn)行管理。組合模式就是將要管理的對(duì)象按樹(shù)型結(jié)構(gòu)來(lái)進(jìn)行組織,表示成一種“整體-部分”的層次結(jié)構(gòu),使得用戶對(duì)單個(gè)對(duì)象和組合對(duì)象的使用具有一致性。組合模式的結(jié)構(gòu)圖如下:
組件接口:提供一致的訪問(wèn)接口,注意組件接口可以是抽象類,也可以是具體類,還可以用接口實(shí)現(xiàn);
組合對(duì)象:含有孩子對(duì)象的對(duì)象;
葉子對(duì)象:不含孩子對(duì)象的對(duì)象。
組合對(duì)象自己維護(hù)一個(gè)子對(duì)象池,并按照組件接口的要求提供一致的訪問(wèn)方式,組合對(duì)象充當(dāng)容器類職責(zé),而葉子對(duì)象則不需要維護(hù) 子對(duì)象池,但也必須按組件接口要求實(shí)現(xiàn)統(tǒng)一的訪問(wèn)處理方式。
使用場(chǎng)景:
A)你想表示對(duì)象的“部分-整體”層次結(jié)構(gòu);
B)你希望用戶忽略單個(gè)對(duì)象合組合對(duì)象的不同,用戶將統(tǒng)一的使用組合結(jié)構(gòu)中的所有對(duì)象;
典型的應(yīng)用包括Delphi中的Component,C#中的控件Control,畫(huà)圖中的圖形表示,業(yè)務(wù)中的組織結(jié)構(gòu)表示,物料BOM,系統(tǒng)的功能結(jié)構(gòu),HTML的DOM模型等等。
與其它模式的區(qū)別:
從結(jié)構(gòu)圖上來(lái)看組合模式和裝飾模式很相近,相同之處是兩種模式都提供了一種組合,裝飾模式提供的是一種功能的組合,而組合模式提供的是一種對(duì)象組合。不同之處在于裝飾模式只維護(hù)一個(gè)構(gòu)件的引用,而組合模式中的組合對(duì)象提維護(hù)的是一個(gè)組件池,數(shù)量上有區(qū)別,這個(gè)區(qū)別就決定了裝飾模式并不能構(gòu)成樹(shù)型結(jié)構(gòu),而組合模式則可以。 從業(yè)務(wù)邏輯上來(lái)講,裝飾模式的使用是為了給構(gòu)件增加新的行為特征,而組合模式是為了整體-局部的層次型管理。從應(yīng)用上來(lái)講,組合模式的應(yīng)用比裝飾模式更具一般化,因此使用更廣。
另外裝飾模式中裝飾者和構(gòu)件并不一定要求同一類對(duì)象,在使用上也有區(qū)別,而組合模式中的組合對(duì)象和葉子對(duì)象都是同一類對(duì)象,在使用上并無(wú)區(qū)別。
組合模式的設(shè)計(jì)方法不僅在程序設(shè)計(jì)上應(yīng)用非常廣,在業(yè)務(wù)設(shè)計(jì)上,數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)上都應(yīng)用非常廣泛。
在使用組合模式時(shí),為了提供更靈活的訪問(wèn),在接口組件提供對(duì)父節(jié)點(diǎn)的訪問(wèn)接口,葉子對(duì)象和組合對(duì)象都會(huì)實(shí)現(xiàn)這種接口,比如Delphi中Wincontrol類中的Parent屬性,C#中Control類中的Parent等。還可以提供對(duì)象檢索之類的功能。
在具體實(shí)現(xiàn)組合模式時(shí),有時(shí)候根據(jù)需要,組合對(duì)象的子對(duì)象池只保持一個(gè)對(duì)子對(duì)象的引用,所有的對(duì)象會(huì)用一個(gè)集合來(lái)進(jìn)行管理,這樣做的好處主要是為了方便對(duì)對(duì)象的檢索和管理。比如索引對(duì)象,釋放資源。樹(shù)型訪問(wèn)有的時(shí)候會(huì)比較慢。典型應(yīng)用就是Delphi中的Form類。所有在Form中創(chuàng)建并指定了Owner屬性的控件,都在Form的Components列表中。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
