当前位置: 首页 > news >正文

【设计模式】Java设计模式 - 组合模式

【设计模式】Java设计模式 - 组合模式

😄 不断学习才是王道
🔥 继续踏上学习之路,学之分享笔记
👊 总有一天我也能像各位大佬一样
🏆 一个有梦有戏的人 @怒放吧德德
🌝分享学习心得,欢迎指正,大家一起学习成长!

今天很累,下班后打了会球,回来洗完澡吃饭继续干!加油!

组合模式

  • 【设计模式】Java设计模式 - 组合模式
    • 简介
    • 组合模式原理
    • 组合模式实例
      • ①、定义抽象类-Component
    • ②、定义叶子类和非叶子类
      • ③、测试

请添加图片描述

简介

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

组合模式原理

首先先看一下组合的UML图
在这里插入图片描述

Compoent:抽象类或者接口,是组合对象声明的接口,实现所有类的默认行为,用于访问、管理子部件。
Leaf:组合中的叶子节点,最小的类
Composite:非叶子节点,用来操作组合对象,存储子部件。

组合模式实例

接下来用一个例子来学习组合模式,学校有学院,学院下有专业,这就是一层一层的关系,需要在一个页面中展现出那个学校有什么学院,学院下有什么专业。
来看一下例子的类图
在这里插入图片描述

①、定义抽象类-Component

定义属性,构造器,getset,操作方法需要默认实现,因为在叶子节点是不需要去实现的,如果定义成抽象类,子类就必须实现了。在定义一个抽象类-打印信息。

package com.lyd.demo.composite;

/**
 * @Author: lyd
 * @Description: 抽象类
 * @Date: 2022-08-30
 */
public abstract class OrganizationComponent {
    private String name;
    private String description;
    public OrganizationComponent(String name, String description) {
        this.name = name;
        this.description = description;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public String getDescription() {
        return description;
    }
    public void setDescription(String description) {
        this.description = description;
    }
    // 添加 - 子类不一定需要实现
    public void add(OrganizationComponent organizationComponent) {
        throw new UnsupportedOperationException();
    }
    // 删除 - 子类不一定需要实现
    public void remove(OrganizationComponent organizationComponent) {
        throw new UnsupportedOperationException();
    }
    // 打印 - 子类必须去实现
    public abstract void print();
}

②、定义叶子类和非叶子类

大学类:非叶子,组合 院系类;定义一个数组来存放组合对象,通过重写操作方法对其进行操作。

package com.lyd.demo.compose;
import com.lyd.demo.composite.OrganizationComponent;
import java.util.ArrayList;
import java.util.List;
/**
 * @Author: lyd
 * @Description: 学校类 - 继承OrganizationComponent - 组合 院系类
 * @Date: 2022-08-30
 */
public class University extends OrganizationComponent {
    // 组合 College 类
    List<OrganizationComponent> organizationComponents = new ArrayList<OrganizationComponent>();
    public University(String name, String description) {
        super(name, description);
    }
    /**
     * 重写add
     */
    @Override
    public void add(OrganizationComponent organizationComponent) {
        organizationComponents.add(organizationComponent);
    }
    /**
     * 重写remove
     */
    @Override
    public void remove(OrganizationComponent organizationComponent) {
        organizationComponents.add(organizationComponent);
    }
    @Override
    public String getName() {
        return super.getName();
    }
    @Override
    public String getDescription() {
        return super.getDescription();
    }
    // 打印包含学院的信息
    @Override
    public void print() {
        System.out.println("< " + getName() + " >");
        // 将所有学院信息打印出来
        for (OrganizationComponent o : organizationComponents) {
            o.print();
        }
    }
}

学院类:非叶子,组合Department类,定义一个数组来存放组合对象,通过重写操作方法对其进行操作。

package com.lyd.demo.compose;
import com.lyd.demo.composite.OrganizationComponent;
import java.util.ArrayList;
import java.util.List;
/**
 * @Author: lyd
 * @Description: 学院类
 * @Date: 2022-08-30
 */
public class College extends OrganizationComponent {
    // 组合 Department 类
    List<OrganizationComponent> organizationComponents = new ArrayList<OrganizationComponent>();
    public College(String name, String description) {
        super(name, description);
    }
    /**
     * 重写add
     */
    @Override
    public void add(OrganizationComponent organizationComponent) {
        organizationComponents.add(organizationComponent);
    }
    /**
     * 重写remove
     */
    @Override
    public void remove(OrganizationComponent organizationComponent) {
        organizationComponents.add(organizationComponent);
    }
    @Override
    public String getName() {
        return super.getName();
    }
    @Override
    public String getDescription() {
        return super.getDescription();
    }
    // 打印包含学院的信息
    @Override
    public void print() {
        System.out.println("< " + getName() + " >");
        // 将所有专业信息打印出来
        for (OrganizationComponent o : organizationComponents) {
            o.print();
        }
    }
}

专业类:叶子节点,没有组合的集合,所以不需要进行操作,只需要进行输出打印。

package com.lyd.demo.compose;
import com.lyd.demo.composite.OrganizationComponent;
/**
 * @Author: lyd
 * @Description: 专业类
 * @Date: 2022-08-30
 */
public class Department extends OrganizationComponent {
    // 已经没有集合了
    public Department(String name, String description) {
        super(name, description);
    }
    @Override
    public String getName() {
        return super.getName();
    }
    @Override
    public String getDescription() {
        return super.getDescription();
    }
    // 叶子节点,就不需要add和remove
    @Override
    public void print() {
        System.out.println(getName());
    }
}

③、测试

package com.lyd.demo.test;
import com.lyd.demo.compose.College;
import com.lyd.demo.compose.Department;
import com.lyd.demo.compose.University;
import com.lyd.demo.composite.OrganizationComponent;
/**
 * @Author: lyd
 * @Description: 测试
 * @Date: 2022-08-30
 */
public class ComposeTest {
    public static void main(String[] args) {
        // 创建大学
        OrganizationComponent ZheJiangUniversity = new University("浙江大学", "人才之地");
        // 创建学院
        OrganizationComponent ComputerCollege = new College("计算机科学与技术学院", "-->计算机科学与技术学院");
        OrganizationComponent OpticalCollege = new College("光电科学与工程学院", "-->光电科学与工程学院");
        // 创建专业
        Department ComputerDepartment = new Department("计算机科学与技术", "--计算机科学与技术");
        Department SoftWareDepartment = new Department("软件工程", "--软件工程");
        Department OpticalDepartment = new Department("光电信息科学与工程", "--光电信息科学与工程");
        // 添加专业
        ComputerCollege.add(ComputerDepartment);
        ComputerCollege.add(SoftWareDepartment);
        OpticalCollege.add(OpticalDepartment);
        // 添加学院
        ZheJiangUniversity.add(ComputerCollege);
        ZheJiangUniversity.add(OpticalCollege);
        // 打印所有
        ZheJiangUniversity.print();
        System.out.println("*******************************");
        // 打印学院
        ComputerCollege.print();
        System.out.println("*******************************");
        // 打印院系
        ComputerDepartment.print();
    }
}

组合可以理解成是层层相套。
运行结果:
在这里插入图片描述
通俗的讲,组合模式就是将对象组合到非类中,在非子类中进行对他们的操作,有种层层相套的感觉,可以通过打断点的形式一步一步了解。

👍创作不易,可能有些语言不是很通畅,如有错误请指正,感谢观看!记得一键三连哦!👍

相关文章:

  • Android之Handler(上)
  • 网络协议:网络安全
  • php防止SQL注入的网上二手交易平台的设计与实现毕业设计-附源码241552
  • 美团笔试题目(Java后端5题2小时)
  • HTML期末大学生网页设计作业——奇恩动漫HTML (1页面) HTML CSS JS网页设计期末课程大作业
  • 浅谈如何学习网络编程
  • 【MYSQL】表的增删改查
  • 中国地板工具租赁服务行业竞争态势与经营效益预测报告2022-2028年
  • 查看docker 容器的端口
  • xubuntu16.04系统中隐藏网络连接的弹窗提示
  • 基于HTML的环境网站设计 HTML+CSS环保网站项目实现 带设计说明psd
  • 第25集丨人生中最高的精神价值
  • php+mysql计算机公共课在线学习网站
  • Git工具快速入门_一小时速成
  • 声明式HTTP客户端-Feign 使用入门详解
  • Effective Java 笔记(一)
  • ES6系列(二)变量的解构赋值
  • fetch 从初识到应用
  • java多线程
  • Java知识点总结(JDBC-连接步骤及CRUD)
  • Netty源码解析1-Buffer
  • PAT A1050
  • PhantomJS 安装
  • React-flux杂记
  • ReactNativeweexDeviceOne对比
  • spring学习第二天
  • vue的全局变量和全局拦截请求器
  • Work@Alibaba 阿里巴巴的企业应用构建之路
  • 安装python包到指定虚拟环境
  • 从输入URL到页面加载发生了什么
  • ​​​​​​​ubuntu16.04 fastreid训练过程
  • #NOIP 2014# day.1 生活大爆炸版 石头剪刀布
  • (4)事件处理——(2)在页面加载的时候执行任务(Performing tasks on page load)...
  • (ZT)北大教授朱青生给学生的一封信:大学,更是一个科学的保证
  • (二)pulsar安装在独立的docker中,python测试
  • (二)Pytorch快速搭建神经网络模型实现气温预测回归(代码+详细注解)
  • (二十一)devops持续集成开发——使用jenkins的Docker Pipeline插件完成docker项目的pipeline流水线发布
  • .NET Core 网络数据采集 -- 使用AngleSharp做html解析
  • .net framwork4.6操作MySQL报错Character set ‘utf8mb3‘ is not supported 解决方法
  • .Net mvc总结
  • .skip() 和 .only() 的使用
  • /etc/motd and /etc/issue
  • @Autowired和@Resource的区别
  • @JsonFormat与@DateTimeFormat注解的使用
  • @JsonSerialize注解的使用
  • @RequestParam详解
  • [ 数据结构 - C++]红黑树RBTree
  • []串口通信 零星笔记
  • [AIGC codze] Kafka 的 rebalance 机制
  • [BUG] Hadoop-3.3.4集群yarn管理页面子队列不显示任务
  • [C++]拼图游戏
  • [GXYCTF2019]禁止套娃
  • [java基础揉碎]方法的重写/覆盖
  • [jquery]this触发自身click事件,当前控件向上滑出
  • [LeetCode] Binary Tree Preorder Traversal 二叉树的先序遍历