組合模式是一種常見的設(shè)計(jì)模式(但我感覺有點(diǎn)復(fù)雜)也叫合成模式,有時(shí)又叫做部分-整體模式,主要是用來描述部分與整體的關(guān)系。
個(gè)人理解:組合模式就是將部分組裝成整體。
定義如下:
將對(duì)象組合成樹形結(jié)構(gòu)以表示“部分-整體”的層次結(jié)構(gòu),使得用戶對(duì)單個(gè)對(duì)象和組合對(duì)象的使用具有一致性。
通用類圖如下:
組合模式的包含角色:
● Component 抽象構(gòu)件角色
定義參加組合對(duì)象的共有方法和屬性,可以定義一些默認(rèn)的行為或?qū)傩浴?/p>
● Leaf 葉子構(gòu)件
葉子對(duì)象,其下再也沒有其他的分支,也就是遍歷的最小單位。
● Composite 樹枝構(gòu)件
樹枝對(duì)象,它的作用是組合樹枝節(jié)點(diǎn)和葉子節(jié)點(diǎn)形成一個(gè)樹形結(jié)構(gòu)。
通用源代碼:
1
2
3
4
5
6
7
|
抽象構(gòu)件 public abstract class Component { //個(gè)體和整體都具有的共享 public void do Something(){ //編寫業(yè)務(wù)邏輯 } } |
樹枝構(gòu)建
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
public class Composite extends Component { //構(gòu)件容器 private Array List<component> component Array List = new Array List<component>() //增加一個(gè)葉子構(gòu)件或樹枝構(gòu)件 public void add(Component component){ this .component Array List.add(component); } //刪除一個(gè)葉子構(gòu)件或樹枝構(gòu)件 public void remove(Component component){ this .component Array List.remove(component); } //獲得分支下的所有葉子構(gòu)件和樹枝構(gòu)件 public Array List<component> get Children(){ return this .component Array List; } } |
樹葉節(jié)點(diǎn)是沒有子下級(jí)對(duì)象的對(duì)象,定義參加組合的原始對(duì)象行為。
1
2
3
4
5
6
7
8
9
10
|
樹葉構(gòu)件 public class Leaf extends Component { /* * 可以覆寫父類方法 * public void do Something(){ * * } */ } |
測(cè)試類負(fù)責(zé)樹狀結(jié)構(gòu)的建立,并可以通過遞歸方式遍歷整個(gè)樹。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
public class Client { public static void main(String[] args) { //創(chuàng)建一個(gè)根節(jié)點(diǎn) Composite root = new Composite(); root. do Something(); //創(chuàng)建一個(gè)樹枝構(gòu)件 Composite branch = new Composite(); //創(chuàng)建一個(gè)葉子節(jié)點(diǎn) Leaf leaf = new Leaf(); //建立整體 root.add(branch); branch.add(leaf); } //通過遞歸遍歷樹 public static void display(Composite root){ for (Component c:root.get Children()){ if (c instanceof Leaf){ //葉子節(jié)點(diǎn) c. do Something(); } else { //樹枝節(jié)點(diǎn) display((Composite)c); } } } } |
組合模式的優(yōu)點(diǎn):
● 高層模塊調(diào)用簡(jiǎn)單
一棵樹形機(jī)構(gòu)中的所有節(jié)點(diǎn)都是Component,局部和整體對(duì)調(diào)用者來說沒有任何區(qū)別,也就是說,高層模塊不必關(guān)心自己處理的是單個(gè)對(duì)象還是整個(gè)組合結(jié)構(gòu),簡(jiǎn)化了高層模塊的代碼。
● 節(jié)點(diǎn)自由增加
使用了組合模式后,我們可以看看,如果想增加一個(gè)樹枝節(jié)點(diǎn)、樹葉節(jié)點(diǎn)是不是都很容易,只要找到它的父節(jié)點(diǎn)就成,非常容易擴(kuò)展,符合開閉原則,對(duì)以后的維護(hù)非常有利。
組合模式的缺點(diǎn):
組合模式有一個(gè)非常明顯的缺點(diǎn),看到我們?cè)趫?chǎng)景類中的定義,提到樹葉和樹枝使用時(shí)的定義了嗎?直接使用了實(shí)現(xiàn)類!這在面向接口編程上是很不恰當(dāng)?shù)模c依賴倒置原則沖突,讀者在使用的時(shí)候要考慮清楚,它限制了你接口的影響范圍。
使用場(chǎng)景:
● 維護(hù)和展示部分-整體關(guān)系的場(chǎng)景,如樹形菜單、文件和文件夾管理。
● 從一個(gè)整體中能夠獨(dú)立出部分模塊或功能的場(chǎng)景。
注意事項(xiàng):
只要是樹形結(jié)構(gòu),就要考慮使用組合模式,這個(gè)一定要記住,只要是要體現(xiàn)局部和整體的關(guān)系的時(shí)候,而且這種關(guān)系還可能比較深,考慮一下組合模式吧。
總結(jié)
以上就是本文關(guān)于快速理解Java設(shè)計(jì)模式中的組合模式的全部?jī)?nèi)容,希望對(duì)大家有所幫助。有什么問題可以隨時(shí)留言,小編會(huì)及時(shí)回復(fù)大家的。感謝朋友們對(duì)本站的支持!
原文鏈接:https://www.2cto.com/kf/201609/546832.html