目录

java23种设计模式—— 一、设计模式介绍

java23种设计模式—— 二、单例模式

java23种设计模式——三、工厂模式

java23种设计模式——四、原型模式

java23种设计模式——五、建造者模式

java23种设计模式——六、适配器模式

java23种设计模式——七、桥接模式

java23种设计模式——八、组合模式

介绍

组合模式(Composite Pattern),又叫部分整体模式,是用于把一组相似的对象当作一个单一的对象。组合模式依据树形结构来组合对象,用来表示部分以及整体层次。这种类型的设计模式属于结构型模式,它创建了对象组的树形结构。

这种模式创建了一个包含自己对象组的类。该类提供了修改相同对象组的方式。

组合模式类似树形结构,上一层节点的包含多个下一层的节点,而下一层的节点只依附于一个上一层的节点。

实现

我们先来看下组合模式的角色。

  • Component抽象构建角色,抽象共有的方法和属性,
  • Leaf叶子构件,叶子对象,没有其他分支,类似于树叶
  • Composite数值构件,组合叶子和其他树枝组合成一个完整的树,类似于树枝

通常大学里都有很多个系,每个系又包含多个专业,每个专业也有多个班级。

首先有一个抽象学校类,即component角色

/**
* @author codermy
* @createTime 2020/7/28
*/
//学校
public abstract class School {
//展示树形结构
public abstract void display(String f);
//添加分支
public void add(School branch){
throw new UnsupportedOperationException("不支持此功能");
};
//删除分支
public void remove(School branch) {
// 若叶子对象没有这个功能,或子类未实现这个功能
throw new UnsupportedOperationException("不支持此功能");
} }

现在有一个Branch类(即Composite角色)继承了学校类,并实现其中方法。我们可以把它抽象的想成,学校的分院与专业的结构都一样,所以新建它们都公用这一个类

/**
* @author codermy
* @createTime 2020/7/28
* 分院
*/
public class Branch extends School {
//学校集合
private List<School> schoolList = new ArrayList<>(); private String name; public Branch(String name){
this.name=name;
} @Override
public void display(String f) {
System.out.println(f + name);
// 如果还包含其他子组件,那么就输出这些子组件对象
if (null != schoolList) {
// 添加一个空格,表示向后缩进一个空格
f += "---";
// 输出当前对象的子组件对象
for (School school : schoolList) {
// 递归地进行子组件相应方法的调用,输出每个子组件对象
school.display(f);
}
}
} public void add(School branch){
schoolList.add(branch);
} public void remove(School branch){
schoolList.remove(branch);
}
}

而学校里最小的单元是班级,新建这个类(即Leaf)

/**
* @author codermy
* @createTime 2020/7/28
*/
public class Class extends School {
private String name; public Class(String name){
this.name = name;
} @Override
public void display(String f) {
System.out.println(f + "-"+ name);
}
}

client类测试

/**
* @author codermy
* @createTime 2020/7/28
*/
public class Client {
public static void main(String[] args) {
//新建一个学校
School university = new Branch("南京大学");
//新建分院
School branch1 = new Branch("计算机与软件学院");
School branch2 = new Branch("外国语学院");
//新建专业
School profession1 = new Branch("软件工程");
School profession2 = new Branch("网络工程");
//新建班级
profession1.add(new Class("软件1801"));
profession1.add(new Class("软件1802")); branch1.add(profession1);
branch1.add(profession2);
university.add(branch1);
university.add(branch2);
university.display("-");
}
}

输出

-南京大学
----计算机与软件学院
-------软件工程
-----------软件1801
-----------软件1802
-------网络工程
----外国语学院

优缺点

优点:

  • 1、高层模块调用简单。
  • 2、节点自由增加。
  • 3、可以清楚地定义分层次的复杂对象,表示对象的全部或部分层次,使得增加新构件也更容易。

缺点:

  • 1、在使用组合模式时,其叶子和树枝的声明都是实现类,而不是接口,违反了依赖倒置原则。
  • 2、使设计变得更加抽象,对象的业务规则如果很复杂,则实现组合模式具有很大挑战性。

java23种设计模式——八、组合模式的更多相关文章

  1. 【Unity3D与23种设计模式】组合模式(Composite)

    前段时间在忙一个新项目 博客好久没有更新了 GoF中定义: "将对象以树状结构组合,用以表现部分-全体的层次关系.组合模式让客户端在操作各个对象或组合时是一致的." 是一致的意思就 ...

  2. 二十四种设计模式:组合模式(Composite Pattern)

    组合模式(Composite Pattern) 介绍将对象组合成树形结构以表示"部分-整体"的层次结构.它使得客户对单个对象和复合对象的使用具有一致性.示例有一个Message实体 ...

  3. 23种设计模式之组合模式(Composite)

    组合模式又称为整体-部分(Part-whole)模式,属于对象的结构模式.在组合模式中,通过组合多个对象形成树形结构以表示整体-部分的结构层次.组合模式对单个对象(即叶子对象)和组合对象(即容器对象) ...

  4. Java--23种设计模式之decorator模式

    装饰模式:装饰模式以对客户端透明的方式扩展对象的功能,是继承关系的一个替代方案,提供比继承更多的灵活性.动态给一个对象增加功能,这些功能可以再动态的撤消.增加由一些基本功能的排列组合而产生的非常大量的 ...

  5. java23种设计模式之四:建造者模式

    在软件开发过程中有时需要创建一个复杂的对象,这个复杂对象通常由多个子部件按一定的步骤组合而成.例如:在新招收一个员工时,对个人信息对象的创建,在不同的阶段,需要个人信息的内容也不一样,姓名.性别.年龄 ...

  6. java23种设计模式之一: 策略模式

    由于最近在研究学习设计模式,我会用自己的理解方式来表述对设计模式的学习和认识,通过最常用.好记的案例来记住和使用设计模式,希望对设计代码方面有所提高和改进. 一.应用背景     在软件开发中常常遇到 ...

  7. java23种设计模式之: 策略模式,观察者模式

    策略模式  --老司机开车,但是他今天想到路虎,明天想开奔驰...针对他不同的需求,来产生不同的应对策略    策略类是一个接口,定义了一个大概的方法,而实现具体的策略则是由实现类完成的,这样的目的是 ...

  8. java23种设计模式之一: 代理模式(动态代理)

    在学习Spring的时候,我们知道Spring主要有两大思想,一个是IoC,另一个就是AOP,对于IoC,依赖注入就不用多说了,而对于Spring的核心AOP来说,我们不但要知道怎么通过AOP来满足的 ...

  9. java23种设计模式之五:代理模式

    一.代理模式介绍 代理模式的定义:就是为一个接品(对象)提供一个代理的对象,并由这个代理对象控制对原对象的访问流程 其中代理又分为:静态代理和动态代理 静态代理:指的是自己要写一个代理类,或者用工具生 ...

随机推荐

  1. 从包含10个无符号数的字节数组array中选出最小的一个数存于变量MIN中,并将该数以十进制形式显示出来。

    问题 从包含10个无符号数的字节数组array中选出最小的一个数存于变量MIN中,并将该数以十进制形式显示出来. 代码 data segment arrey db 0,1,2,4,6,5,7,9,8, ...

  2. Python List len()方法

    描述 len() 方法返回列表元素个数.高佣联盟 www.cgewang.com 语法 len()方法语法: len(list) 参数 list -- 要计算元素个数的列表. 返回值 返回列表元素个数 ...

  3. 最新 laravel5.8 连接redis集群

    简介 Redis 是一个开源的,高级键值对存储数据库.由于它包含 字符串 , 哈希 , 列表 , 集合 , 和 有序集合 这些数据类型,所以它通常被称为数据结构服务器. 在使用 Laravel 的 R ...

  4. 5.15 牛客挑战赛40 E 小V和gcd树 树链剖分 主席树 树状数组 根号分治

    LINK:小V和gcd树 时限是8s 所以当时好多nq的暴力都能跑过. 考虑每次询问暴力 跳父亲 这样是nq的 4e8左右 随便过. 不过每次跳到某个点的时候需要得到边权 如果直接暴力gcd的话 nq ...

  5. electron 开发 - win7 运行后白屏 黑屏

    解决思路: localhost:3000本地react项目确保运行无误 electron 官方demo跑一遍确认不是配置问题 切换electron版本,发现5可以6不行 google 官方issue ...

  6. Linux的VMWare14中配置Centos7桥接网络环境(网络一)

    1.查看当前初始环境如下:在windows端先查看本机ip   ifconfig

  7. Redis好文章推荐

    文章来源:掘金   作者:敖丙 Redis-避免缓存穿透的利器之BloomFilter <我们一起进大厂>系列- Redis基础 <我们一起进大厂>系列-缓存雪崩.击穿.穿透 ...

  8. 什么是DO,DTO,VO,POJO

    俗话说,没有规矩不成方圆,今天来说一下 Java 中的各种 O(bject). 为什么会出现这些 O? 我们知道,这些 O 不管叫什么名字,其本质都还是对象(Object),既然本质都一样,为什么非要 ...

  9. Spring的第一个程序

    目录 一.Spring概述 1. Spring是什么? 2. IOC控制反转 二.Spring的第一个程序 1. 创建Maven项目 2. 加入maven依赖pom.xml 3. 定义接口和实体类 4 ...

  10. C#LeetCode刷题之#104-二叉树的最大深度​​​​​​​(Maximum Depth of Binary Tree)

    问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/4072 访问. 给定一个二叉树,找出其最大深度. 二叉树的深度为根 ...