一、概述

将对象组合成树型结构以表示“部分--整体”的层次关系。组合模式使得用户对单个对象和组合对象的使用具有一致性。

二、适用性

1.你想表示对象的部分--整体层次结构的时候。

2.你希望用户忽略组合对象与单个对象的不同的时候,用户将统一地使用组合结构中的所有对象。

三、参与者

1.Component:为组合中的对象声明接口。在适当的情况下,实现所有类共有接口的缺省行为。声明一个接口用于访问和管理Component的子组件。在递归结构中定义一个接口,用于访问一个父部件,并且在适当的情况下实现它。

2.Leaf:在组合中表示叶节点对象,叶节点没有子节点。在组合中定义节点对象的行为。

3.Composite:定义有子部件的那些部件的行为。存储子部件。在Component接口中实现与子部件有关的操作。

4.Client:通过Component接口操作组合部件的对象。

四、类图

五、示例

Component

  1. package cn.lynn.composite;
  2. import java.util.List;
  3. public abstract class Saint {
  4. private String name;
  5. protected List<Saint> saints;
  6. public List<Saint> getSaints() {
  7. return saints;
  8. }
  9. public String getName() {
  10. return name;
  11. }
  12. public void setName(String name) {
  13. this.name = name;
  14. }
  15. public void printInfo() {
  16. System.out.println(name);
  17. }
  18. protected abstract void obtain(Saint saint);
  19. protected abstract void deprive(Saint saint);
  20. }

Leaf

  1. package cn.lynn.composite;
  2. public class BronzeSaint extends Saint {
  3. public BronzeSaint(String name) {
  4. super.setName(name);
  5. super.saints = null; // 青铜圣斗士已经是最低级的
  6. }
  7. @Override
  8. public void obtain(Saint saint) {
  9. }
  10. @Override
  11. public void deprive(Saint saint) {
  12. }
  13. }
  1. package cn.lynn.composite;
  2. public class SilverSaint extends Saint {
  3. public SilverSaint(String name) {
  4. super.setName(name);
  5. super.saints = null; // 白银圣斗士比青铜圣斗士强点
  6. }
  7. @Override
  8. public void obtain(Saint saint) {
  9. }
  10. @Override
  11. public void deprive(Saint saint) {
  12. }
  13. }

Composite

  1. package cn.lynn.composite;
  2. import java.util.ArrayList;
  3. public class GoldSaint extends Saint {
  4. public GoldSaint(String name) {
  5. super.setName(name);
  6. super.saints = new ArrayList<Saint>(); // 还是黄金圣斗士牛逼,竟然会修圣衣
  7. }
  8. @Override
  9. public void obtain(Saint saint) {
  10. super.saints.add(saint);
  11. }
  12. @Override
  13. public void deprive(Saint saint) {
  14. super.saints.remove(saint);
  15. }
  16. }

Client

  1. package cn.lynn.composite;
  2. import java.util.List;
  3. public class Client {
  4. public static void main(String[] args) {
  5. Saint goldSaint = new GoldSaint("穆先生");
  6. Saint silverSaint = new SilverSaint("魔铃");
  7. Saint bronzeSaint1 = new BronzeSaint("星矢");
  8. Saint bronzeSaint2 = new BronzeSaint("一辉");
  9. Saint bronzeSaint3 = new BronzeSaint("紫龙");
  10. goldSaint.obtain(silverSaint);
  11. goldSaint.obtain(bronzeSaint1);
  12. goldSaint.obtain(bronzeSaint2);
  13. goldSaint.obtain(bronzeSaint3);
  14. StringBuffer sb = new StringBuffer();
  15. sb.append(goldSaint.getName()+"指导");
  16. List<Saint> saints = goldSaint.getSaints();
  17. for (Saint saint : saints) {
  18. sb.append(saint.getName());
  19. sb.append("、");
  20. }
  21. sb = sb.deleteCharAt(sb.length() - 1);
  22. sb.append("修圣衣!");
  23. System.out.println(sb.toString());
  24. }
  25. }

Result

  1. 穆先生指导魔铃、星矢、一辉、紫龙修圣衣!

GoF23种设计模式之结构型模式之组合模式的更多相关文章

  1. GoF23种设计模式之结构型模式之桥接模式

    一.概述         将类的抽象部分与实现分部分离开来,使它们都可以独立地变化. 二.适用性 1.你不希望在抽象和实现之间有一个固定的绑定关系的时候.例如:在程序运行时实现部分应可以被选择或切换. ...

  2. GoF23种设计模式之结构型模式之外观模式

    一.概述         为子系统中的一组接口提供一个一致的界面,外观模式定义了一个高层接口,这个接口使得这一子系统更加容易使用. 二.适用性 1.当你要为一个复杂子系统提供一个简单接口的时候.子系统 ...

  3. GoF23种设计模式之结构型模式之代理模式

    一.概述 为其他对象提供一种代理以控制对这个对象的访问. 二.适用性 1.远程代理(RemoteProxy):为一个对象在不同的地址空间土工局部代表. 2.虚代理(VirtualProxy):根据需要 ...

  4. GoF23种设计模式之结构型模式之享元模式

    一.概述  运用共享技术有效地支持大量细粒度的对象. 二.适用性 1.当一个应用程序使用了大量的对象的时候. 2.由于使用大量的独享而造成很大的存储开销的时候. 3.对象的大多数状态都可变为外部状态的 ...

  5. GoF23种设计模式之结构型模式之适配器模式

    一.概述         将一个类的接口转换成客户希望的另外一个接口.适配器模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作. 二.适用性 1.你想使用一个已经存在的类,但是它的接口不符合 ...

  6. GoF23种设计模式之结构型模式之装饰模式

    一.概述 动态地给一个对象添加一些额外的职责.装饰模式比生成子类更为灵活. 二.适用性 1.在不影响其他对象的情况下,以动态.透明的方式给但个对象添加职责. 2.处理那些可以撤销的职责. 3.当不能采 ...

  7. Go语言实现的23种设计模式之结构型模式

    摘要:本文主要聚焦在结构型模式(Structural Pattern)上,其主要思想是将多个对象组装成较大的结构,并同时保持结构的灵活和高效,从程序的结构上解决模块之间的耦合问题. 本文分享自华为云社 ...

  8. Java经典23种设计模式之结构型模式(一)

    结构型模式包含7种:适配器模式.桥接模式.组合模式.装饰模式.外观模式.享元模式.代理模式. 本文主要介绍适配器模式和桥接模式. 一.适配器模式(Adapter) 适配器模式事实上非常easy.就像手 ...

  9. GoF的23种设计模式之结构型模式的特点和分类

    结构型模式描述如何将类或对象按某种布局组成更大的结构.它分为类结构型模式和对象结构型模式,前者采用继承机制来组织接口和类,后者釆用组合或聚合来组合对象. 由于组合关系或聚合关系比继承关系耦合度低,满足 ...

随机推荐

  1. js中 前台日期时间使用方法总结

    (1)JQuery EasyUI 1.4.2  版本中的    DateTimeBox(时间日期输入框) 参考本地帮助文档. (2)jquery.datetimepicker   单独使用的包   只 ...

  2. HDU 1160 FatMouse's Speed LIS DP

    http://acm.hdu.edu.cn/showproblem.php?pid=1160 同样是先按它的体重由小到大排,相同就按speed排就行. 这样做的好处是,能用O(n^2)枚举,因为前面的 ...

  3. MongoDB 最初级步骤

    对库TEST下的LOG聚集集合中的inserttim字段加索引 步骤(注意:前四步步骤不能错,错了不行): 一,打开F:\mongodb\bin\mongo.exe,也可以用cmd命令指到这个exe执 ...

  4. Java基础:(六)关键字

    一.final 数据: 声明数据为常量,可以是编译时常量,也可以是在运行时被初始化后不能被改变的常量. 对于基本类型,final使数值不变: 对于引用类型,final使引用不变,也就不能引用其他对象, ...

  5. Servlet之sendRedirect和getRequestDispatch

    Servlet的请求重定向和请求转发方法的比较分析: 1.getRequestDispatch是属于httpServletRequest对象的方法,请求转发是在同一个请求中完成的,因此整个过程只包含一 ...

  6. $.ajax同步/异步(async:false/true)

    虽然说ajax用来执行异步请求的比较多,但有时还是存在需要同步执行的情况的. 比如:我需要通过ajax取执行请求以返回一个值,这个值在ajax后面是需要使用到的,这时就不能用异步请求了.这时候就需要使 ...

  7. java 通过文件后缀名查找文件

    最近开发项目的时候需要过滤出一些指定的文件,所以有了以下的一些代码: /** **该类主要是过滤得到指定后缀名的文件 **/ public class DataFileFilter implement ...

  8. 【extjs6学习笔记】1.5 初始:关于布局

    absolute 绝对布局,这个布局使用 x 和 y 属性来指定组件的绝对定位 accordion 手风琴布局[可折叠布局]这个布局展示了在一个时间里只有一个内置的可支持折叠和展开的子级 panel ...

  9. jsp四大作用域之Session

    <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding= ...

  10. linux yum安装指定版本mysql

    1.下载mysql rpm包 cd /usr/local/src wget https://dev.mysql.com/get/mysql80-community-release-el7-.noarc ...