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-06
mybatis攔截器實現(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

