设计模式总结篇系列:组合模式(Composite)

简介:

在探讨Java组合模式之前,先要明白几个概念的区别:继承、组合和聚合。

继承是is-a的关系。组合和聚合有点像,有些书上没有作区分,都称之为has-a,有些书上对其进行了较为严格区分,组合是contains-a关系,聚合是has-a关系。

组合方式中被组合的对象生命周期不能超过整体,一般写代码时是直接在整体类的构造方法中创建被组合类的对象。如人和手之间的关系,人都没了,还何来手?

聚合方式中对于对象的生命周期则没有此类限制,一般可以在聚合类的构造函数中通过外部传参以赋值给整体(或通过其他set等函数形式),如人有一台电脑的关系。

总体说来,组合关系相对聚合而言整体和部分关系感更强一些。

回到正题,组合模式中当然在组合对象中含有被组合对象的引用,只是不同的是,组合模式在概念上更加严格,通常是指引用的被组合对象类型就是组合对象的类型。如此一来,使得组合对象和被组合对象处理起来具有一致性。当然,前提是组合被对象和被组合对象在本身的概念层次上具有此一致性。

最为经典的体现组合模式的例子是具有树形结构特点的类定义。对于树形结构中的每个结点,由于父结点的孩子节点有可能是有自己的孩子结点,因此,利用组合模式,将所有结点统一设计成同一种类型即可。

1.定义树中结点类, 每个结点都有结点名称,父节点和孩子结点:

复制代码
 1 class TreeNode {
 2 
 3     private String name;
 4     private TreeNode parent;
 5     private Vector<TreeNode> children = new Vector<TreeNode>();
 6 
 7     public TreeNode() {
 8     }
 9 
10     public TreeNode(String name) {
11         this.name = name;
12     }
13 
14     public String getName() {
15         return name;
16     }
17 
18     public void setName(String name) {
19         this.name = name;
20     }
21 
22     public TreeNode getParent() {
23         return parent;
24     }
25 
26     public void setParent(TreeNode parent) {
27         this.parent = parent;
28     }
29 
30     public Vector<TreeNode> getChildren() {
31         return children;
32     }
33 
34     public void setChildren(Vector<TreeNode> children) {
35         this.children = children;
36     }
37 
38     // 添加孩子结点
39     public void addChild(TreeNode child) {
40         children.add(child);
41     }
42 
43     // 删除子结点
44     public void removeChild(TreeNode child) {
45         children.remove(child);
46     }
47 
48     // 获取子结点
49     public Enumeration<TreeNode> getChileren() {
50         return children.elements();
51     }
52 
53 }
复制代码

2.客户端类,创建树:

复制代码
 1 public class Tree {
 2 
 3     private TreeNode root;
 4 
 5     public Tree() {
 6 
 7     }
 8 
 9     public Tree(String treeName) {
10         root = new TreeNode(treeName);
11     }
12 
13     public static void main(String[] args) {
14         Tree tree = new Tree("A");
15         TreeNode nodeB = new TreeNode("B");
16         TreeNode nodeC = new TreeNode("C");
17         nodeB.addChild(nodeC);
18         tree.root.addChild(nodeB);
19         System.out.println("build the tree finished!");
20     }
21 
22 }
复制代码

 

---------------------------------------------------------------------------------
笔者水平有限,若有错漏,欢迎指正,如果转载以及CV操作,请务必注明出处,谢谢!
分类: 设计模式

本文转自Windstep博客园博客,原文链接:http://www.cnblogs.com/lwbqqyumidi/p/3758182.html,如需转载请自行联系原作者
目录
相关文章
|
4月前
|
设计模式
二十三种设计模式全面解析-组合模式与迭代器模式的结合应用:构建灵活可扩展的对象结构
二十三种设计模式全面解析-组合模式与迭代器模式的结合应用:构建灵活可扩展的对象结构
|
3天前
|
设计模式 Java 容器
【设计模式系列笔记】组合模式
组合模式(Composite Pattern)是一种结构型设计模式,它允许将对象组合成树状结构以表示部分-整体的层次结构。组合模式使得客户端可以统一处理单个对象和对象组合,而无需区分它们的类型。
36 12
|
12天前
|
设计模式 Java
小谈设计模式(20)—组合模式
小谈设计模式(20)—组合模式
|
1月前
|
设计模式 JavaScript uml
设计模式之组合模式
设计模式之组合模式
设计模式之组合模式
|
1月前
|
设计模式 存储 安全
【设计模式】组合模式
【设计模式】组合模式
|
2月前
|
设计模式 Java
浅谈设计模式 - 组合模式(十二)
浅谈设计模式 - 组合模式(十二)
51 0
|
3月前
|
设计模式 存储 安全
聊聊Java设计模式-组合模式
组合(Composite)模式,又叫做树形模式,主要用来处理树形结构数据。是将一组对象组织成树形结构,以表示一种“部分-整体”的层次结构。让客户端可以统一单个对象和组合对象的处理逻辑
29 1
聊聊Java设计模式-组合模式
|
3月前
|
设计模式 存储
设计模式 | 组合模式
设计模式 | 组合模式
12 0
|
3月前
|
设计模式 Go 开发工具
Golang设计模式——17组合模式
Golang设计模式——17组合模式
13 1
|
3月前
|
设计模式 存储 前端开发
【设计模式】之组合模式
组合模式是一种非常有用的设计模式,在前端开发中经常用于处理复杂的层次结构和嵌套关系。它通过将对象组合成树形结构来表示“部分-整体”的关系,并提供了一种优雅而灵活的方式来处理复杂性。通过使用组合模式,我们可以构建可扩展和易于维护的应用程序。然而,需要根据具体情况权衡使用组合模式所带来的优缺点。
39 0