Java設計模式之-組合模式

什么是組合模式?

組合模式允許你將對象組合成樹形結構來表示"部分-整體"的層次結構。它讓客戶端能夠以統一的方式處理單個對象對象組合

簡單來說,就像公司的組織結構:

  • 公司有部門
  • 部門有小組
  • 小組有員工
  • 但無論是對公司、部門還是員工,都可以統一執行"工作"操作

主要解決什么問題?

組合模式主要解決處理樹形結構數據時的問題:

  1. 客戶端需要區分簡單元素(葉子節點)和復雜元素(容器節點)
  2. 處理容器節點時需要遞歸處理其子節點
  3. 希望用統一接口處理所有節點,無論它是簡單還是復雜

何時使用組合模式?

當你發現以下場景時,考慮使用組合模式:

  • 需要表示對象的部分-整體層次結構
  • 希望用戶忽略組合對象與單個對象的不同
  • 結構可以形成任意深度的樹形嵌套
  • 需要對整個樹形結構執行統一操作(如渲染、計算等)

組合模式的優點

  1. 簡化客戶端代碼:客戶端可以一致地處理單個對象和組合對象
  2. 開閉原則:容易新增組件類型,無需修改現有代碼
  3. 靈活的結構:可以構建任意復雜的樹形結構
  4. 統一操作:對整個結構執行操作變得簡單

組合模式的缺點

  1. 過度一般化:有時很難為所有組件定義通用接口
  2. 類型檢查問題:運行時可能需要檢查對象類型
  3. 設計復雜:需要仔細設計組件接口,可能變得過于抽象

代碼示例:文件系統

讓我們用文件系統的例子來演示組合模式:

import java.util.ArrayList;
import java.util.List;// 組件抽象類(可以是接口)
abstract class FileSystemComponent {protected String name;public FileSystemComponent(String name) {this.name = name;}public abstract void display(int depth);public abstract long getSize();// 默認實現(葉子節點不需要實現)public void add(FileSystemComponent component) {throw new UnsupportedOperationException();}public void remove(FileSystemComponent component) {throw new UnsupportedOperationException();}
}// 葉子節點:文件
class File extends FileSystemComponent {private long size;public File(String name, long size) {super(name);this.size = size;}@Overridepublic void display(int depth) {System.out.println("-".repeat(depth) + name + " (" + size + " bytes)");}@Overridepublic long getSize() {return size;}
}// 容器節點:目錄
class Directory extends FileSystemComponent {private List<FileSystemComponent> children = new ArrayList<>();public Directory(String name) {super(name);}@Overridepublic void display(int depth) {System.out.println("-".repeat(depth) + "[D] " + name);for (FileSystemComponent component : children) {component.display(depth + 2);}}@Overridepublic long getSize() {long totalSize = 0;for (FileSystemComponent component : children) {totalSize += component.getSize();}return totalSize;}@Overridepublic void add(FileSystemComponent component) {children.add(component);}@Overridepublic void remove(FileSystemComponent component) {children.remove(component);}
}// 客戶端代碼
public class CompositePatternDemo {public static void main(String[] args) {// 創建文件File file1 = new File("document.txt", 1024);File file2 = new File("image.jpg", 2048);File file3 = new File("notes.txt", 512);// 創建子目錄Directory subDir = new Directory("SubFolder");subDir.add(file2);subDir.add(file3);// 創建根目錄Directory rootDir = new Directory("Root");rootDir.add(file1);rootDir.add(subDir);// 顯示整個文件系統結構System.out.println("File System Structure:");rootDir.display(1);// 計算總大小System.out.println("\nTotal Size: " + rootDir.getSize() + " bytes");}
}

輸出結果:

File System Structure:
- [D] Root
---document.txt (1024 bytes)
--- [D] SubFolder
-----image.jpg (2048 bytes)
-----notes.txt (512 bytes)Total Size: 3584 bytes

實際應用場景

組合模式在Java中有許多實際應用:

  1. GUI組件:Swing/AWT中的Container和Component
  2. XML/HTML解析:DOM樹結構
  3. 組織架構:公司部門人員管理
  4. 文件系統:如上面的示例
  5. 菜單系統:菜單和菜單項

總結

組合模式通過將對象組織成樹形結構,讓我們能夠以統一的方式處理單個對象和組合對象。它特別適合表示部分-整體層次結構,使得添加新類型的組件變得容易,同時保持代碼的簡潔性。

關鍵點在于:

  • 定義一個既能代表葉子又能代表容器的抽象
  • 容器需要存儲子組件并實現管理方法
  • 葉子節點實現基礎行為
  • 客戶端代碼可以統一處理所有組件

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/914749.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/914749.shtml
英文地址,請注明出處:http://en.pswp.cn/news/914749.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

2021-10-29 C++與反轉數的和

緣由輸入一個三位數 與它倒過來的數相加&#xff0c;輸出和-編程語言-CSDN問答 直接寫 int n0,nn0,nnn0; cin>>n;nnn; while(nn)nnn*10,nnnnn%10,nn/10; cout<<nnnn<<endl; 緣由https://ask.csdn.net/questions/7552128 int 反轉數(int n) { int nn 0…

論安全架構設計(威脅與措施)

安全架構威脅與措施摘要2021年4月&#xff0c;我有幸參與了某保險公司的“優車險”項目的建設開發工作&#xff0c;該系統以車險報價、車險投保和報案理賠為核心功能&#xff0c;同時實現了年檢代辦、道路救援、一鍵挪車等增值服務功能。在本項目中&#xff0c;我被安排擔任架構…

022_提示緩存與性能優化

提示緩存與性能優化 目錄 緩存技術概述緩存工作原理實現方法詳解成本優化策略性能優化實踐高級應用場景最佳實踐指南 緩存技術概述 什么是提示緩存 提示緩存是Claude API的一項優化功能&#xff0c;允許緩存提示的特定部分以便重復使用&#xff0c;從而顯著減少處理時間和…

【AI交叉】地理:人工智能如何推動地理科學的智能轉型?

隨著人工智能&#xff08;AI&#xff09;技術的快速發展&#xff0c;越來越多的傳統學科開始與之融合&#xff0c;催生出一系列跨學科的新研究方向和應用場景。地理科學作為研究地球表層自然與人文現象的綜合性學科&#xff0c;也在這一浪潮中迎來轉型契機。 AI與地理學的交叉正…

iOS高級開發工程師面試——關于網絡

iOS高級開發工程師面試——關于網絡 一、談談對 HTTP、HTTPS 的理解1. HTTP協議:2. HTTPS 協議二、TCP、UDP 和 SocketTCPUDPTCP 和 UDP 的區別?Socket一、談談對 HTTP、HTTPS 的理解 1. HTTP協議: 超文本傳輸協議,他是基于TCP應用層協議。 是無連接 無狀態 的,需要通過…

跟著Nature正刊學作圖:回歸曲線+散點圖

&#x1f4cb;文章目錄復現目標圖片繪圖前期準備繪制左側回歸線圖繪制右側散點圖組合拼圖 (關鍵步驟&#xff01;)跟著「Nature」正刊學作圖&#xff0c;今天挑戰復現Nature文章中的一張組合圖–左邊為 回歸曲線、右邊為 散點圖。這種組合圖在展示相關性和分組效應時非常清晰有…

LVS集群調度器

目錄 集群和分布式 LVS運行原理 LVS概念 LVS的集群類型 實驗配置 安裝LVS ipvsadm命令參數 1.管理集群服務中的增刪改 2.管理集群服務中的RS增刪改 3.lvs調度策略的備份與恢復 4.lvs調度策略的開機啟動 LVS-NAT模式 LVS-DR模式 集群和分布式 集群&#xff08;Clu…

【React Natve】NetworkError 和 TouchableOpacity 組件

NetworkError公共組件 import SimpleLineIcons from "expo/vector-icons/SimpleLineIcons"; import { StyleSheet, Text, View } from "react-native";export default function NetworkError() {return (<View style{styles.container}><SimpleL…

Linux 驅動中 Timer / Tasklet / Workqueue 的作用與對比

Linux 驅動中 Timer / Tasklet / Workqueue 的作用與對比 &#x1f9e9; 1. 使用場景概覽&#xff08;對比表&#xff09;機制執行上下文是否可睡眠使用場景常用接口Timer中斷上下文? 不可睡眠延遲執行&#xff08;如防抖、超時處理&#xff09;add_timer() 等Tasklet軟中斷上…

JavaScript中關于proxy的作用以及和Object.defineProperty的區別

之前寫了一篇介紹 Object.defineProperty的&#xff0c;提到proxy&#xff0c;二者有一些共性&#xff0c;也都是前端框架Vue的核心機制&#xff0c;所以再寫一篇介紹一下proxy的基礎原理和使用。 在 JavaScript 中&#xff0c;Proxy 是 ES6 引入的一個元編程特性&#xff0c;用…

HTTP性能優化實戰技術

HTTP性能優化實戰技術文章大綱 理解HTTP性能優化的核心指標 關鍵指標&#xff1a;延遲、吞吐量、TTFB&#xff08;Time To First Byte&#xff09;、頁面加載時間影響性能的因素&#xff1a;網絡延遲、服務器響應時間、資源大小、協議效率 減少HTTP請求數量 合并資源文件&#…

ubuntu(22.04)系統上安裝 MuJoCo

在 Linux 系統上安裝 MuJoCo 的完整步驟如下&#xff1a; ??1. 下載 MuJoCo?? 訪問 MuJoCo 官方 GitHub下載最新 Linux 版本&#xff08;如 mujoco-3.3.4-linux-x86_64.tar.gz&#xff09;獲取對應的 SHA256 校驗值&#xff08;在發布頁面可以找到,&#xff0c;文件名后面…

理解大模型的對話和檢索能力

RAG和聯網搜索均通過“檢索生成”模式擴展模型能力&#xff0c;但RAG基于內部知識庫&#xff08;如企業文檔&#xff09;&#xff0c;適合專業領域問答&#xff1b;聯網搜索實時檢索互聯網&#xff0c;解決時效性問題&#xff08;如新聞、股價&#xff09;。RAG響應快且可控&am…

跟著Carl學算法--回溯【2】

IP復原&#xff08;難&#xff09; 力扣鏈接&#xff1a;IP復原 題目&#xff1a;有效 IP 地址 正好由四個整數&#xff08;每個整數位于 0 到 255 之間組成&#xff0c;且不能含有前導 0&#xff09;&#xff0c;整數之間用 . 分隔。 例如&#xff1a;"0.1.2.201"…

PyTorch生成式人工智能(17)——變分自編碼器詳解與實現

PyTorch生成式人工智能(17)——變分自編碼器詳解與實現 0. 前言1. 潛空間運算2. 變分自編碼器2.1 自編碼器與變分自編碼器對比2.2 模型訓練流程3. 構建變分自編碼器3.1 模型構建3.2 模型訓練3.3 生成圖像4. 向量運算小結系列鏈接0. 前言 雖然自編碼器 (AutoEncoder, AE) 在重…

SpringMVC2

一、接口聲明的穩定性- 接口聲明不能輕易變&#xff1a;接口是前后端、服務間通信的約定。要是接口的 URL、請求方法、參數、返回值變了&#xff0c;調用方&#xff08;比如前端、其他服務&#xff09;就得跟著改&#xff0c;容易出問題。所以設計接口要謹慎&#xff0c;別老變…

LVS集群實踐

一、LVS概念VS: Virtual Sever &#xff08;調度器&#xff09;RS: Real Sever &#xff08;資源主機&#xff09;CIP: Client IP &#xff08;用戶IP&#xff09;VIP: Virtual sever IP &#xff08;VS外網的IP&#xff0c;客戶訪問的IP&#xff09;DIP: Director IP &#xf…

使用Django框架構建Python Web應用

前言Django個高級Python Web框架&#xff0c;遵循MTV&#xff08;Model-Template-View&#xff09;設計模式&#xff1a;模型(Model)&#xff1a;數據層&#xff0c;定義數據結構模板(Template)&#xff1a;表現層&#xff0c;處理用戶界面視圖(View)&#xff1a;業務邏輯層&am…

[AI-video] 數據模型與架構 | LLM集成

第五章&#xff1a;數據模型與架構 歡迎來到第五章&#xff01; 在前幾章中&#xff0c;我們學習了網頁用戶界面&#xff08;UI&#xff09;&#xff08;控制面板&#xff09;、應用配置&#xff08;系統參數設置&#xff09;、任務編排&#xff08;視頻生成流程的總調度&…

HTTP 性能優化實戰:突破高并發瓶頸的工業級方案

在互聯網高并發場景中&#xff0c;HTTP 性能表現直接決定系統生死。當每秒請求量突破十萬級甚至百萬級時&#xff0c;哪怕 100 毫秒的延遲都會引發用戶流失、交易失敗等連鎖反應。本文基于五大行業實戰案例&#xff0c;拆解 HTTP 性能瓶頸的底層邏輯&#xff0c;輸出可直接落地…