一、概述

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

二、适用性

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. 【bzoj4567】[Scoi2016]背单词

    4567: [Scoi2016]背单词 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1123 Solved: 476[Submit][Status][ ...

  2. 牛客网Java刷题知识点之为什么static成员方法不能是抽象方法,其必须实现

    不多说,直接上干货! static修饰的方法我们称之为静态方法,我们通过类名对其进行直接调用.由于它在类加载的时候就存在了,它不依赖于任何实例,所以static方法必须实现,也就是说它不能是抽象方法.

  3. 使用OAuth保护REST API并使用简单的Angular客户端

    1.概述 在本教程中,我们将使用OAuth保护REST API并从简单的Angular客户端使用它. 我们要构建的应用程序将包含四个独立的模块: 授权服务器 资源服务器 UI implicit - 使 ...

  4. MVC中验证码的简单使用

    首先新建一个MVC项目 添加类:验证码帮助类(ValidateCodeHelper) using System; using System.Collections.Generic; using Sys ...

  5. MVC3 自定义的错误页

    ASP.NET MVC3中如果配置文件出错了,怎么跳转到自定义的错误页,现在参考网上的档案是说 添加 如下配置文件,并且在路径Views/Shared/下添加Error页面,测试下没有用的,请大家看看 ...

  6. 实例——省市区三级联动 & 还可以输入字符统计

    1 省市区三级联动 html代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8" ...

  7. Author: Jan Odvarko, www.janodvarko.cz

    /*  * Author: Jan Odvarko, www.janodvarko.cz */ FBL.ns(function() { with (FBL) { function HelloWorld ...

  8. Hybrid框架安全隐患分析

    Hybrid框架安全隐患分析 目前我司移动端项目中各种app如雨后春笋般生根发芽层出不穷.而利用Hybrid框架确实可以减轻一部分移动端压力.并且做到灵活发版.但是其中的安全问题往往让人忽略. 针对A ...

  9. pm2-web监控

    pm2-web 是一款 pm2 服务状态监控程序,基于 web . 安装 npm install -g pm2-web 运行(默认占用8080端口) pm2-web 自定义配置文件 通过 --conf ...

  10. Python + selenium之unitest(2)

    unittest单元测试框架中重要的概念: 1.Test Case 一个Test Case实例就是一个测试用例.在一个完整的测试流程中,包括测试前准备环境的搭建(setUp),实现测试过程的代码(ru ...