组合设计模式解读

简介: 组合设计模式解读

65199e49017248bd81ed866404584895.png

问题引进

看一个学校院系展示需求
编写程序展示一个学校院系结构:需求是这样,要在一个页面中展示出学校的院系组成,一个学校有多个学院

传统方案解决学校院系展示(类图)

传统方案解决学校院系展示存在的问题分析

1) 将学院看做是学校的子类,系是学院的子类,这样实际上是站在组织大小来进行分层次的
2) 实际上我们的要求是 :在一个页面中展示出学校的院系组成,一个学校有多个学院,一个学院有多个系, 因此这种方案,不能很好实现的管理的操作,比如对学院、系的添加,删除,遍历等
3) 解决方案:把学校、院、系都看做是组织结构,他们之间没有继承的关系,而是一个树形结构,可以更好的实现管理操作。 => 组合模式

组合模式基本介绍

基本介绍

1) 组合模式(Composite Pattern),又叫部分整体模式,它创建了对象组的树形结构,将对象组合成树状结构以
表示“整体-部分”的层次关系。
2) 组合模式依据树形结构来组合对象,用来表示部分以及整体层次。
3) 这种类型的设计模式属于结构型模式。
4) 组合模式使得用户对单个对象和组合对象的访问具有一致性,即:组合能让客户以一致的方式处理个别对象及组合对象

组合模式原理类图

对原理结构图的说明-即(组合模式的角色及职责)

1) Component :这是组合中对象声明接口,在适当情况下,实现所有类共有的接口默认行为,用于访问和管理Component 子部件, Component 可以是抽象类或者接口
2) Leaf : 在组合中表示叶子节点,叶子节点没有子节点
3) Composite :非叶子节点, 用于存储子部件, 在 Component 接口中实现 子部件的相关操作,比如增加(add),删除。

应用实例

应用实例要求

1) 编写程序展示一个学校院系结构:需求是这样,要在一个页面中展示出学校的院系组成,一个学校有多个学院,
一个学院有多个系。
2) 思路分析和图解(类图
)

OrganizationComponent  

1. public abstract class OrganizationComponent {
2. private  String name;//名字
3. private  String des;// 说明
4. 
5. protected  void  add(OrganizationComponent organizationComponent){
6. throw  new UnsupportedOperationException();
7.     }
8. 
9. protected  void  remove(OrganizationComponent organizationComponent){
10. throw   new UnsupportedOperationException();
11.     }
12. 
13. public OrganizationComponent(String name, String des) {
14. this.name = name;
15. this.des = des;
16.     }
17. 
18. public String getName() {
19. return name;
20.     }
21. 
22. public void setName(String name) {
23. this.name = name;
24.     }
25. 
26. public String getDes() {
27. return des;
28.     }
29. 
30. public void setDes(String des) {
31. this.des = des;
32.     }
33. protected  abstract  void print();
34. }

College  

1. public class College extends OrganizationComponent {
2. //List 中 存放的 Department
3.     List<OrganizationComponent> list = new ArrayList<OrganizationComponent>();
4. 
5. // 构造器
6. public College(String name, String des) {
7. super(name, des);
8. 
9.     }
10. 
11. // 重写 add
12. @Override
13. protected void add(OrganizationComponent organizationComponent) {
14. 
15. //将来实际业务中,Colleage 的 add 和 University add 不一定完全一样
16.         list.add(organizationComponent);
17.     }
18. 
19. // 重写 remove
20. @Override
21. protected void remove(OrganizationComponent organizationComponent) {
22.         list.remove(organizationComponent);
23.     }
24. 
25. @Override
26. public String getName() {
27. return super.getName();
28.     }
29. 
30. @Override
31. public String getDes() {
32. return super.getDes();
33.     }
34. 
35. // print 方法,就是输出 University 包含的学院
36. @Override
37. protected void print() {
38.         System.out.println("--------------" + getName() + "--------------");
39. //遍历 organizationComponents
40. for (OrganizationComponent organizationComponent : list) {
41.             organizationComponent.print();
42.         }
43. 
44.     }
45. }

University

University 就是 Composite , 可以管理 College

1. 
2. public class University extends  OrganizationComponent{
3. 
4.    List<OrganizationComponent> list= new ArrayList<>();
5. 
6. public University(String name, String des) {
7. super(name, des);
8.     }
9. 
10. @Override
11. protected void print() {
12.         System.out.println("----------"+getName()+"------------");
13. for (OrganizationComponent organizationComponent : list) {
14.            organizationComponent.print();
15.         }
16.     }
17. 
18. @Override
19. protected void add(OrganizationComponent organizationComponent) {
20.         list.add(organizationComponent);
21.     }
22. 
23. @Override
24. protected void remove(OrganizationComponent organizationComponent) {
25.         list.remove(organizationComponent);
26.     }
27. 
28. }

Department

1. public class Department extends  OrganizationComponent{
2. public Department(String name, String des) {
3. super(name, des);
4.     }
5. 
6. //没有集合
7. 
8. @Override
9. public void setName(String name) {
10. super.setName(name);
11.     }
12. 
13. @Override
14. public void setDes(String des) {
15. super.setDes(des);
16.     }
17. 
18. @Override
19. protected void print() {
20.         System.out.println(getName());
21.     }
22. }

client

1. public class client {
2. public static void main(String[] args) {
3. //从大到小创建对象 学校
4. OrganizationComponent university = new University("清华大学", " 中国顶级大学 ");
5. //创建 学院
6. OrganizationComponent computerCollege = new College("计算机学院", " 计算机学院 ");
7. OrganizationComponent infoEngineercollege = new College("信息工程学院", " 信息工程学院 ");
8. //创建各个学院下面的系(专业)
9.         computerCollege.add(new Department("软件工程", " 软件工程不错 "));
10.         computerCollege.add(new Department("网络工程", " 网络工程不错 "));
11.         computerCollege.add(new Department("计算机科学与技术", " 计算机科学与技术是老牌的专业 "));
12. 
13.         infoEngineercollege.add(new Department("通信工程", " 通信工程不好学 "));
14.         infoEngineercollege.add(new Department("信息工程", " 信息工程好学 "));
15. //将学院加入到 学校
16.         university.add(computerCollege);
17.         university.add(infoEngineercollege);
18.         university.print();
19. 
20.     }
21. }

组合模式的注意事项和细节

1) 简化客户端操作。客户端只需要面对一致的对象而不用考虑整体部分或者节点叶子的问题。
2) 具有较强的扩展性。当我们要更改组合对象时,我们只需要调整内部的层次关系,客户端不用做出任何改动.
3) 方便创建出复杂的层次结构。客户端不用理会组合里面的组成细节,容易添加节点或者叶子从而创建出复杂的树形结构
4) 需要遍历组织机构,或者处理的对象具有树形结构时, 非常适合使用组合模式.
5) 要求较高的抽象性,如果节点和叶子有很多差异性的话,比如很多方法和属性都不一样,不适合使用组合模式


相关文章
|
2月前
|
设计模式 安全 Java
【设计模式】2、设计模式分类和单例设计模式
【设计模式】2、设计模式分类和单例设计模式
36 0
|
2月前
|
设计模式 搜索推荐 数据库连接
第二篇 创建型设计模式 - 灵活、解耦的创建机制
第二篇 创建型设计模式 - 灵活、解耦的创建机制
|
2月前
|
设计模式 监控 安全
多线程设计模式【多线程上下文设计模式、Guarded Suspension 设计模式、 Latch 设计模式】(二)-全面详解(学习总结---从入门到深化)
多线程设计模式【多线程上下文设计模式、Guarded Suspension 设计模式、 Latch 设计模式】(二)-全面详解(学习总结---从入门到深化)
73 0
|
存储 设计模式 前端开发
【Java设计模式 面向对象设计思想】四 基于接口而非实现编程
【Java设计模式 面向对象设计思想】四 基于接口而非实现编程
79 0
|
设计模式 存储 算法
【Java设计模式 经典设计原则】六 KISS、YAGNI和DRY原则
【Java设计模式 经典设计原则】六 KISS、YAGNI和DRY原则
102 0
|
设计模式 算法 前端开发
前端通用编程基础的设计模式之模板方法
模板方法模式是一种常见的设计模式,它可以帮助我们在一个方法中定义算法的骨架,并将其实现延迟到子类中。下面就让我们来看看模板方法模式的特点和优势。
68 0
|
设计模式 前端开发
前端通用编程基础的设计模式之观察者
观察者模式是前端开发中非常常见且实用的一种设计模式。该模式可以帮助我们更好地设计和实现一些复杂的应用程序,例如事件处理、数据绑定以及状态管理等。
97 0
|
设计模式 存储 C++
【设计模式学习笔记】组合模式与桥接模式案例详解(C++实现)
【设计模式学习笔记】组合模式与桥接模式案例详解(C++实现)
304 0
【设计模式学习笔记】组合模式与桥接模式案例详解(C++实现)
|
设计模式 存储 C++
【设计模式学习笔记】外观模式和享元模式案例详解(C++实现)
【设计模式学习笔记】外观模式和享元模式案例详解(C++实现)
308 0
【设计模式学习笔记】外观模式和享元模式案例详解(C++实现)
|
设计模式 Java 数据库连接
23种设计模式-结构模式-享元模式(十二)
23种设计模式-结构模式-享元模式(十二)
23种设计模式-结构模式-享元模式(十二)