欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java設計模式中的組合模式

 更新時間:2022年07月19日 09:17:18   作者:愛學習的大魚  
這篇文章主要介紹了Java設計模式中的組合模式,組合模式依據樹形結構來組合對象,用來表示部分以及整體層次,種類型的設計模式屬于結構型模式

模式介紹

  • 組合模式(Composite Pattern),又叫部分整體模式,它創(chuàng)建了對象組的樹形結構,將對象組合成樹狀結構以表示“整體_部分”的層次關系。
  • 組合模式依據樹形結構來組合對象,用來表示部分以及整體層次。
  • 這種類型的設計模式屬于結構型模式。
  • 組合模式使得用戶對單個對象和組合對象的訪問具有一致性,即:組合能讓客戶以一-致的方式處理個別對象以及組合對象

UML類圖

類圖解析:

  • Component :這是組合中對象聲明接口,在適當情況下,實現所有類共有的接口默認行為,用于訪問和管理。Component子部件, Component可以是抽象類或者接口。
  • Leaf:在組合中表示葉子節(jié)點,葉子節(jié)點沒有子節(jié)點
  • Composite :非葉子節(jié)點,用于存儲子 部件,在 Component接口中實現子部件的相關操作,比如增加(add),刪除(delete)。

組合模式案例

背景介紹:一所大學包含多個學院,學院又包含多個學科專業(yè)

OrganizationComponent(抽象類)

public abstract class OrganizationComponent {
    private String name;
    private String des;
    /**
     * 默認實現
     * @param o
     */
    protected void add(OrganizationComponent o) {
        throw new UnsupportedOperationException("該方法不支持");
    }
    protected void remove(OrganizationComponent o) {
        throw new UnsupportedOperationException("該方法不支持");
    }
    public OrganizationComponent(String name, String des) {
        this.name = name;
        this.des = des;
    }
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getDes() {
        return des;
    }

    public void setDes(String des) {
        this.des = des;
    }

    /**
     * 打印方法
     */
    protected abstract void print();
}

Department(專業(yè)類)

public class Department extends OrganizationComponent{
    public Department(String name, String des) {
        super(name, des);
    }
    @Override
    protected void print() {
        System.out.println(getName());
    }
}

College(學院類)

public class College extends OrganizationComponent {
    List<OrganizationComponent> departments = new ArrayList<>();

    public College(String name, String des) {
        super(name, des);
    }
    @Override
    protected void add(OrganizationComponent o) {
        departments.add(o);
    }
    @Override
    protected void remove(OrganizationComponent o) {
        departments.remove(o);
    }
    @Override
    protected void print() {
        System.out.println("-----------" + getName() + "-----------");
        departments.forEach(OrganizationComponent::print);
    }
}

University(大學類)

public class University extends OrganizationComponent {
    List<OrganizationComponent> colleges = new ArrayList<>();

    public University(String name, String des) {
        super(name, des);
    }

    @Override
    protected void add(OrganizationComponent o) {
        colleges.add(o);
    }

    @Override
    protected void remove(OrganizationComponent o) {
        colleges.remove(o);
    }
    @Override
    protected void print() {
        System.out.println("-----------" + getName() + "-----------");
        colleges.forEach(OrganizationComponent::print);
    }
}

Client(測試類)

public class Client {
    public static void main(String[] args) {
        // 創(chuàng)建大學
        University university = new University("清華大學", "中國頂級大學");

        // 計算機學院
        College computerCollege = new College("計算機學院", "計算機學院");
        College infoEngineerCollege = new College("信息工程學院", "信息工程學院");
        // 創(chuàng)建專業(yè) 并添加
        computerCollege.add(new Department("軟件工程","軟件工程不錯"));
        computerCollege.add(new Department("網絡工程","網絡工程不錯"));
        computerCollege.add(new Department("計算機科學與技術","計算機科學與技術老牌專業(yè)"));

        infoEngineerCollege.add(new Department("通信工程","通信工程不好學"));
        infoEngineerCollege.add(new Department("信息工程","信息工程好學"));

        // 添加學院到大學
        university.add(computerCollege);
        university.add(infoEngineerCollege);

        // 打印
        university.print();
    }
}

實現結果:

組合模式的注意事項和細節(jié)

  • 簡化客戶端操作??蛻舳酥恍枰鎸σ恢碌膶ο蠖挥每紤]整體部分或者節(jié)點葉子的問題。
  • 具有較強的擴展性。當我們要更改組合對象時,我們只需要調整內部的層次關系,客戶端不用做出任何改動。
  • 方便創(chuàng)建出復雜的層次結構。客戶端不用理會組合里面的組成細節(jié),容易添加節(jié)點或者葉子從而創(chuàng)建出復雜的樹形結構。
  • 需要遍歷組織機構,或者處理的對象具有樹形結構時,非常適合使用組合模式
  • 要求較高的抽象性,如果節(jié)點和葉子有很多差異性的話,比如很多方法和屬性都不一樣,不適合使用組合模式。

到此這篇關于Java設計模式中的組合模式的文章就介紹到這了,更多相關Java組合模式內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Spring 單元測試中如何進行 mock的實現

    Spring 單元測試中如何進行 mock的實現

    這篇文章主要介紹了Spring 單元測試中如何進行 mock的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • Java中@ConfigurationProperties實現自定義配置綁定問題分析

    Java中@ConfigurationProperties實現自定義配置綁定問題分析

    這篇文章主要介紹了@ConfigurationProperties實現自定義配置綁定問題,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-08-08
  • 在SpringBoot項目中實現讀寫分離的流程步驟

    在SpringBoot項目中實現讀寫分離的流程步驟

    SpringBoot作為一種快速開發(fā)框架,廣泛應用于Java項目中,在一些大型應用中,數據庫的讀寫分離是提升性能和擴展性的一種重要手段,本文將介紹如何在SpringBoot項目中優(yōu)雅地實現讀寫分離,并通過適當的代碼插入,詳細展開實現步驟,同時進行拓展和分析
    2023-11-11
  • 異常點/離群點檢測算法——LOF解析

    異常點/離群點檢測算法——LOF解析

    這篇文章主要介紹了異常點/離群點檢測算法——LOF解析,通過圖解文字描述的方式詳細的解析了該算法,以下就是詳細內容,需要的朋友可以參考下
    2021-07-07
  • IDEA JavaWeb項目啟動運行后出現404錯誤的解決方法

    IDEA JavaWeb項目啟動運行后出現404錯誤的解決方法

    這篇文章主要介紹了IDEA JavaWeb項目啟動運行后出現404錯誤的解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • Java經典排序算法之歸并排序詳解

    Java經典排序算法之歸并排序詳解

    這篇文章主要為大家詳細介紹了Java經典排序算法之歸并排序,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • JUC之Semaphore源碼分析

    JUC之Semaphore源碼分析

    這篇文章主要為大家詳細分析了JUC之Semaphore源碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • ArrayList詳解和使用示例_動力節(jié)點Java學院整理

    ArrayList詳解和使用示例_動力節(jié)點Java學院整理

    ArrayList 是一個數組隊列,相當于 動態(tài)數組。與Java中的數組相比,它的容量能動態(tài)增長。接下來通過本文給大家介紹arraylist詳解和使用示例代碼,需要的的朋友一起學習吧
    2017-05-05
  • 關于Java中properties文件編碼問題

    關于Java中properties文件編碼問題

    這篇文章主要介紹了關于Java中properties文件編碼問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • java.lang.Void類源碼解析

    java.lang.Void類源碼解析

    這篇文章主要介紹了java.lang.Void類源碼解析的相關內容,對源碼中的部分內容進行解釋,具有一定參考價值,需要的朋友可以了解下。
    2017-10-10

最新評論