Java結(jié)構(gòu)型模式中的組合模式詳解
一.介紹
組合模式(Composite Pattern)屬于結(jié)構(gòu)型模式。組合模式又叫作部分整體模式,它是一種將對象組合成樹狀層次結(jié)構(gòu)的模式,用來表示整體-部分的關(guān)系,使用戶對單個對象和組合對象具有一致的訪問性。組合模式有透明方式和安全方式兩種實現(xiàn)方式
二.UML類圖
1.透明方式
- 抽象節(jié)點中定義了規(guī)范,客戶端無需區(qū)別葉子節(jié)點和樹枝節(jié)點,使用方便
- 葉子節(jié)點本來無add、remove、getChild方法,但是因為抽象中定義了規(guī)范,所以必須實現(xiàn)它們,會帶來一些安全性問題
2.安全方式
- 客戶端需要區(qū)別葉子節(jié)點和樹枝節(jié)點,使用不方便
- 葉子節(jié)點無add、remove、getChild方法,不存在安全性問題
三.具體代碼
業(yè)務(wù)代碼
//抽象節(jié)點 public abstract class Component { abstract void add(Component component); abstract void remove(Component component); abstract Component getChild(int i); abstract void operation(); } //葉子節(jié)點 class Leaf extends Component{ private String name; public Leaf(String name) { this.name = name; } @Override void add(Component component) {} @Override void remove(Component component) {} @Override Component getChild(int i) { return null; } @Override void operation() { System.out.print(name); } } //樹枝節(jié)點 class Composite extends Component{ private ArrayList<Component> children = new ArrayList<>(); @Override void add(Component component) { children.add(component); } @Override void remove(Component component) { children.remove(component); } @Override Component getChild(int i) { return children.get(i); } @Override void operation() { children.forEach(Component::operation); } }
客戶端
public class Client { public static void main(String[] args) { Component level1 = new Composite(); level1.add(new Leaf("1")); level1.add(new Leaf("2")); Component level2 = new Composite(); level2.add(new Leaf("2.1")); level1.add(level2); level1.operation(); } }
四.使用場景
- 需要表示一個對象整體與部分的層次結(jié)構(gòu)
- 要求對用戶隱藏組合對象與單個對象的不同,用戶可以使用統(tǒng)一的接口操作組合結(jié)構(gòu)中的所有對象
- 組織機構(gòu)樹
- 文件/文件夾
五.優(yōu)點
- 簡化了客戶端代碼(客戶端一致地處理單個對象和組合對象)
- 符合開閉原則(新增具體實現(xiàn)類不需要更改源代碼)
到此這篇關(guān)于Java結(jié)構(gòu)型模式中的組合模式詳解的文章就介紹到這了,更多相關(guān)Java組合模式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java實現(xiàn)實時監(jiān)控目錄下文件變化的方法
今天小編就為大家分享一篇關(guān)于Java實現(xiàn)實時監(jiān)控目錄下文件變化的方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03如何使用Java模擬退火算法優(yōu)化Hash函數(shù)
為了解決局部最優(yōu)解問題,1983年,Kirkpatrick等提出了模擬退火算法(SA)能有效的解決局部最優(yōu)解問題。模擬退火算法包含兩個部分即Metropolis算法和退火過程。Metropolis算法就是如何在局部最優(yōu)解的情況下讓其跳出來,是退火的基礎(chǔ)2021-06-06mybatis攔截器實現(xiàn)通用權(quán)限字段添加的方法
這篇文章主要給大家介紹了關(guān)于mybatis攔截器實現(xiàn)通用權(quán)限字段添加的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用mybatis具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09