设计模式-组合模式(Composite)

定义 将对象以树形结构组织起来,以达成“部分-整体” 的层次结构,使得客户端对单个对象和组合对象的使用具有一致性.

组合模式有时又叫部分-整体模式在处理类似树形结构的问题时比较方便。

关系图

image.png

使用场景 当发现需求中是体现部分与整体层次的结构时,以及希望用户可以忽略组合对象与单个对象的不同,统一的使用组合结构中的所有对象时,就应该考虑用组合模式了。

将多个对象组合在一起进行操作,常用于表示树形结构中,例如二叉树等。

代码示例

 public class TreeNode { 
       
    private String name; 
    private TreeNode parent; 
    private Vector<TreeNode> children = new Vector<TreeNode>(); 
       
    public TreeNode(String name){ 
        this.name = name; 
    } 
   
    public String getName() { 
        return name; 
    } 
   
    public void setName(String name) { 
        this.name = name; 
    } 
   
    public TreeNode getParent() { 
        return parent; 
    } 
   
    public void setParent(TreeNode parent) { 
        this.parent = parent; 
    } 
       
    //添加孩子节点 
    public void add(TreeNode node){ 
        children.add(node); 
    } 
       
    //删除孩子节点 
    public void remove(TreeNode node){ 
        children.remove(node); 
    } 
       
    //取得孩子节点 
    public Enumeration<TreeNode> getChildren(){ 
        return children.elements(); 
    } 
} 
public class Tree { 
   
    TreeNode root = null; 
   
    public Tree(String name) { 
        root = new TreeNode(name); 
    } 
   
    public static void main(String[] args) { 
        Tree tree = new Tree("A"); 
        TreeNode nodeB = new TreeNode("B"); 
        TreeNode nodeC = new TreeNode("C"); 
           
        nodeB.add(nodeC); 
        tree.root.add(nodeB); 
        System.out.println("build the tree finished!"); 
    } 
} 

个人介绍: ** 高广超** :多年一线互联网研发与架构设计经验,擅长设计与落地高可用、高性能互联网架构。目前就职于美团网,负责核心业务研发工作。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏TechBox

23种设计模式之工厂三兄弟

关于设计模式,是一个永远说不完的也说不清的话题。毕竟在编程的世界里,没有最好的设计模式,只有最合适的设计模式。甚至有些时候,程序或者问题不到一定的规模,尝试所有...

9210
来自专栏java一日一条

如何拿到半数面试公司Offer——我的Python求职之路

从八月底开始找工作,短短的一星期多一些,面试了9家公司,拿到5份Offer,可能是因为我所面试的公司都是些创业性的公司吧,不过还是感触良多,因为学习Python...

10410
来自专栏Albert陈凯

函数式编程初探

http://www.ruanyifeng.com/blog/2012/04/functional_programming.html 诞生50多年之后,函数式编...

363100
来自专栏java学习

面试题46(关于类变量的调用)

下面代码在main方法代码后可以正常使用的是? ---- public class Test{ private int a = 10; int b = 2...

35450
来自专栏CDA数据分析师

如何拿到半数面试公司Offer——我的Python求职之路

从八月底开始找工作,短短的一星期多一些,面试了9家公司,拿到5份Offer,可能是因为我所面试的公司都是些创业性的公司吧,不过还是感触良多,因为学习Python...

30780
来自专栏web前端教室

大周末的不多说,面试十点必看

实事求是的讲,前端新人因为时间的关系,对于JavaScript的理解确实是无法面面具到,甚至有些知识点我讲的比较深入,但因为每个人的程度不同,依然无法做到当堂理...

20250
来自专栏chafezhou

学习Python,怎能不懂点PEP呢?

作者:豌豆花下猫,某985高校毕业生, 兼具极客思维与人文情怀 。公众号Python猫, 专注python技术、数据科学和深度学习,力图创造一个有趣又有用的学习...

15010
来自专栏我和我大前端的故事

数组对象根据对象中指定的属性去重?你知道多少

有一天有一个朋友给我发来消息 “数组对象根据对象中指定的属性去重?让我写写看”,看到这个的时候我有点懵逼,好像不太会。

55730
来自专栏LEo的网络日志

广度优先搜索算法(go)

广度优先搜索算法(Breadth First Search,缩写为BFS),又译作宽度优先搜索,或横向优先搜索,是一种图形搜索算法。简单的说,广度优先搜索算法是...

50830
来自专栏GreenLeaves

初识javascript

1.简介:Javascript是Netscape(网景)公司与Sun公司(现被甲骨文收购)合作开发的一款是网页具备交互能力的程序设计语言。 2.与之功能相同的语...

18090

扫码关注云+社区

领取腾讯云代金券