【设计模式】—— 组合模式Composite
前言:【模式总览】——————————by xingoo
模式意图
使对象组合成树形的结构。使用户对单个对象和组合对象的使用具有一致性。
应用场景
1 表示对象的 部分-整体 层次结构
2 忽略组合对象与单个对象的不同,统一的使用组合结构中的所有对象。
模式结构
【安全的组合模式】
这种组合模式,叶子节点,也就是单个对象不具有对象的控制功能。仅仅有简单的业务操作。
1 package com.xingoo.composite.safe; 2 3 import java.util.ArrayList; 4 import java.util.List; 5 6 interface Component{ 7 Composite getCmposite(); 8 void sampleComposite(); 9 } 10 11 class Leaf implements Component{ 12 13 public Composite getCmposite() { 14 return null; 15 } 16 17 public void sampleComposite() { 18 System.out.println("Leaf operation"); 19 } 20 21 } 22 23 class Composite implements Component{ 24 25 private List<Component> list = new ArrayList(); 26 27 public void add(Component component){ 28 list.add(component); 29 } 30 31 public void remove(Component component){ 32 list.remove(component); 33 } 34 35 public Composite getCmposite() { 36 return this; 37 } 38 39 public void sampleComposite() { 40 System.out.println("Composite operation"); 41 for(Component com : list){ 42 com.sampleComposite(); 43 } 44 } 45 46 } 47 public class Client { 48 public static void main(String[] args) { 49 Component leaf1 = new Leaf(); 50 Component leaf2 = new Leaf(); 51 Component composite = new Composite(); 52 composite.getCmposite().add(leaf1); 53 composite.getCmposite().add(leaf2); 54 composite.getCmposite().sampleComposite(); 55 } 56 }
执行结果
Composite operation
Leaf operation
Leaf operation
【透明的组合模式】
这种组合模式,叶子节点与组合对象具有相同的方法,外表看来毫无差异。不过叶子节点的处理方法默认为空。忽略叶子节点,与组合对象的差异性。
1 package com.xingoo.composite.transparent; 2 3 import java.util.ArrayList; 4 import java.util.List; 5 6 interface Component{ 7 public void SampleOperation(); 8 public void add(Component component); 9 public void remove(Component component); 10 public Component getComponent(); 11 } 12 13 class Leaf implements Component{ 14 public void SampleOperation() { 15 System.out.println("leaf operation!"); 16 } 17 18 public void add(Component component) { 19 20 } 21 22 public void remove(Component component) { 23 24 } 25 26 public Component getComponent(){ 27 return this; 28 } 29 } 30 31 class Composite implements Component{ 32 33 private List<Component> list = new ArrayList(); 34 35 public void SampleOperation() { 36 System.out.println("composite operation!"); 37 for(Component com : list){ 38 com.getComponent().SampleOperation(); 39 } 40 } 41 42 public void add(Component component) { 43 list.add(component); 44 } 45 46 public void remove(Component component) { 47 list.remove(component); 48 } 49 50 public Component getComponent(){ 51 return this; 52 } 53 } 54 public class Client { 55 public static void main(String[] args) { 56 Component leaf1 = new Leaf(); 57 Component leaf2 = new Leaf(); 58 Component leaf3 = new Leaf(); 59 Component composite1 = new Composite(); 60 Component composite = new Composite(); 61 62 composite1.add(leaf3); 63 64 composite.getComponent().add(leaf1); 65 composite.getComponent().add(leaf2); 66 composite.getComponent().add(composite1); 67 68 composite.getComponent().SampleOperation(); 69 } 70 }
本例中的结构层次
执行结果
composite operation! leaf operation! leaf operation! composite operation! leaf operation!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
2012-10-29 windows程序设计-第四章 system2.c 新增滚动条功能
2012-10-29 windows程序设计-第四章 system1.c
2012-10-29 堆 栈-相关知识
2012-10-29 圆排列问题-回溯法