小谈设计模式(20)—组合模式 ╰半夏微凉° 2023-10-16 17:57 8阅读 0赞 #### 小谈设计模式(20)—组合模式 #### * 专栏介绍 * * 专栏地址 * 专栏介绍 * 组合模式 * * 对象类型 * * 叶节点 * 组合节点 * 核心思想 * 应用场景 * * 1 * 2 * 3 * 结构图 * * 结构图分析 * Java语言实现 * * 首先,我们需要定义一个抽象的组件类 Component,它包含了组合节点和叶节点的公共操作: * 然后,我们定义组合节点类 Composite,它实现了 Component 接口,并包含了一个子组件列表: * 最后,我们定义叶节点类 Leaf,它也实现了 Component 接口,但它没有子节点: * 现在,我们可以使用组合模式来创建一个树状结构并操作它: * 运行上述代码,输出结果如下 * 总结 * 优缺点分析 * * 优点 * * 简化客户端代码 * 增加新的节点类型 * 方便地处理递归结构 * 缺点 * * 可能会导致设计过于一般化 * 可能会增加系统的复杂性 ## 专栏介绍 ## ### 专栏地址 ### [link][] ### 专栏介绍 ### 主要对目前市面上常见的23种设计模式进行逐一分析和总结,希望有兴趣的小伙伴们可以看一下,会持续更新的。希望各位可以监督我,我们一起学习进步,加油,各位。 ![在这里插入图片描述][abbf33acae6b4ecfb2c0a387d120574a.png] ## 组合模式 ## 组合模式是一种结构型设计模式,它允许将对象组合成树状结构以表示“部分-整体”的层次结构。组合模式使得客户端可以统一地处理单个对象和组合对象,无需区分它们的区别。 ### 对象类型 ### 叶节点(Leaf)和组合节点(Composite) #### 叶节点 #### 它表示树的最底层的对象,它们没有子节点。 #### 组合节点 #### 它表示树的分支节点,它可以包含其他的组合节点和叶节点。 ![在这里插入图片描述][1bc206c746be400d86016cf7be8ddc52.png] ### 核心思想 ### 使用一个抽象类或接口来定义组合节点和叶节点的公共操作。这样,客户端可以通过调用这些公共操作来处理组合节点和叶节点,而无需知道具体的节点类型。 ![在这里插入图片描述][c6cf488a9e4f4b568fb4dc9dae0edc30.png] ### 应用场景 ### #### 1 #### 需要表示对象的部分-整体层次结构,并且希望客户端能够一致地处理单个对象和组合对象的情况。 #### 2 #### 需要对树状结构进行递归操作,例如遍历树、查找特定节点等。 #### 3 #### 需要动态地增加或删除树的节点。 ![在这里插入图片描述][3a8f95514c804b03ae8849ec17deef0d.png] ### 结构图 ### ![在这里插入图片描述][577afe9d4666485dab6b1d56a4e5d488.png] #### 结构图分析 #### 在上面的结构图中,Component 是组合模式的抽象类或接口,定义了组合节点和叶节点共有的操作。Composite 是组合节点的具体实现,它可以包含其他的组合节点和叶节点。Leaf 是叶节点的具体实现。 ![在这里插入图片描述][29c9aa0c489846708f7944b63d649992.png] ### Java语言实现 ### #### 首先,我们需要定义一个抽象的组件类 Component,它包含了组合节点和叶节点的公共操作: #### public abstract class Component { protected String name; public Component(String name) { this.name = name; } public abstract void operation(); public abstract void add(Component component); public abstract void remove(Component component); public abstract Component getChild(int index); } #### 然后,我们定义组合节点类 Composite,它实现了 Component 接口,并包含了一个子组件列表: #### import java.util.ArrayList; import java.util.List; public class Composite extends Component { private List<Component> children; public Composite(String name) { super(name); children = new ArrayList<>(); } @Override public void operation() { System.out.println("Composite " + name + " operation."); for (Component component : children) { component.operation(); } } @Override public void add(Component component) { children.add(component); } @Override public void remove(Component component) { children.remove(component); } @Override public Component getChild(int index) { return children.get(index); } } #### 最后,我们定义叶节点类 Leaf,它也实现了 Component 接口,但它没有子节点: #### public class Leaf extends Component { public Leaf(String name) { super(name); } @Override public void operation() { System.out.println("Leaf " + name + " operation."); } @Override public void add(Component component) { // 叶节点不支持添加操作 } @Override public void remove(Component component) { // 叶节点不支持删除操作 } @Override public Component getChild(int index) { // 叶节点没有子节点 return null; } } #### 现在,我们可以使用组合模式来创建一个树状结构并操作它: #### public class Main { public static void main(String[] args) { // 创建树状结构 Composite root = new Composite("root"); Composite branch1 = new Composite("branch1"); Composite branch2 = new Composite("branch2"); Leaf leaf1 = new Leaf("leaf1"); Leaf leaf2 = new Leaf("leaf2"); Leaf leaf3 = new Leaf("leaf3"); root.add(branch1); root.add(branch2); branch1.add(leaf1); branch2.add(leaf2); branch2.add(leaf3); // 调用操作方法 root.operation(); } } #### 运行上述代码,输出结果如下 #### Composite root operation. Composite branch1 operation. Leaf leaf1 operation. Composite branch2 operation. Leaf leaf2 operation. Leaf leaf3 operation. #### 总结 #### 以上就是使用Java语言实现组合模式的示例代码。通过组合模式,我们可以方便地处理树状结构,并且客户端可以一致地处理单个对象和组合对象。 ![在这里插入图片描述][9d294455a42446a898fc8f1b59ee0dad.png] ### 优缺点分析 ### #### 优点 #### ##### 简化客户端代码 ##### 客户端可以一致地处理单个对象和组合对象,无需区分它们的差异。 ##### 增加新的节点类型 ##### 通过继承 Component 类,可以方便地增加新的节点类型,而无需修改现有的代码。 ##### 方便地处理递归结构 ##### 组合模式适用于处理递归结构,例如树状结构。 #### 缺点 #### ##### 可能会导致设计过于一般化 ##### 组合模式将叶节点和组合节点都抽象为 Component 类,可能会导致设计过于一般化,不适合特定的场景。 ##### 可能会增加系统的复杂性 ##### 组合模式引入了组合节点和叶节点的层次结构,可能会增加系统的复杂性。 [link]: http://t.csdn.cn/B1YXg [abbf33acae6b4ecfb2c0a387d120574a.png]: https://img-blog.csdnimg.cn/abbf33acae6b4ecfb2c0a387d120574a.png [1bc206c746be400d86016cf7be8ddc52.png]: https://img-blog.csdnimg.cn/1bc206c746be400d86016cf7be8ddc52.png [c6cf488a9e4f4b568fb4dc9dae0edc30.png]: https://img-blog.csdnimg.cn/c6cf488a9e4f4b568fb4dc9dae0edc30.png [3a8f95514c804b03ae8849ec17deef0d.png]: https://img-blog.csdnimg.cn/3a8f95514c804b03ae8849ec17deef0d.png [577afe9d4666485dab6b1d56a4e5d488.png]: https://img-blog.csdnimg.cn/577afe9d4666485dab6b1d56a4e5d488.png [29c9aa0c489846708f7944b63d649992.png]: https://img-blog.csdnimg.cn/29c9aa0c489846708f7944b63d649992.png [9d294455a42446a898fc8f1b59ee0dad.png]: https://img-blog.csdnimg.cn/9d294455a42446a898fc8f1b59ee0dad.png
相关 小谈设计模式(24)—命令模式 小谈设计模式(24)—命令模式 专栏介绍 专栏地址 专栏介绍 命令模式 角色分析 命令(Comman 心已赠人/ 2024年02月23日 02:27/ 0 赞/ 10 阅读
相关 小谈设计模式(19)—备忘录模式 小谈设计模式(19)—备忘录模式 专栏介绍 专栏地址 专栏介绍 备忘录模式 主要角色 发起人(Ori 「爱情、让人受尽委屈。」/ 2023年10月16日 17:47/ 0 赞/ 12 阅读
相关 小谈设计模式(17)—状态模式 小谈设计模式(17)—状态模式 专栏介绍 专栏地址 专栏介绍 状态模式 关键角色 上下文(Conte 青旅半醒/ 2023年10月16日 17:40/ 0 赞/ 9 阅读
相关 小谈设计模式(13)—外观模式 小谈设计模式(13)—外观模式 专栏介绍 专栏地址 专栏介绍 外观模式 主要目的 角色分析 逃离我推掉我的手/ 2023年10月16日 17:12/ 0 赞/ 13 阅读
相关 小谈设计模式(10)—原型模式 小谈设计模式(10)—原型模式 专栏介绍 专栏地址 专栏介绍 原型模式 角色分类 抽象原型(Prot 亦凉/ 2023年10月16日 16:54/ 0 赞/ 11 阅读
相关 小谈设计模式(8)—代理模式 小谈设计模式(8)—代理模式 专栏介绍 专栏地址 专栏介绍 代理模式 代理模式角色分析 抽象主题(S た 入场券/ 2023年10月16日 16:47/ 0 赞/ 6 阅读
相关 小谈设计模式(3)—策略模式 小谈设计模式(3)—策略模式 专栏介绍 专栏地址 专栏介绍 策略模式 主要角色 环境(Context ゞ 浴缸里的玫瑰/ 2023年10月16日 07:26/ 0 赞/ 10 阅读
相关 设计模式—组合模式 组合模式的英文原文是:Compose objects into tree structures to represent part-whole hiearachies. Com た 入场券/ 2022年08月08日 00:46/ 0 赞/ 204 阅读
相关 设计模式 : 组合模式 组合模式 (Composite) ,将对象组合成树形结构以表示, '部分-整体'的层次结构. 组合模式使得用户对单个对象和组合对象的使用具有一致性. ![70][] 曾经终败给现在/ 2022年05月27日 00:55/ 0 赞/ 255 阅读
还没有评论,来说两句吧...