博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
设计模式之组合模式
阅读量:4099 次
发布时间:2019-05-25

本文共 3289 字,大约阅读时间需要 10 分钟。

GoF的设计模式是这么说的:

意图:将对象组合成树形结构以表示“部分-整体”的层次结构。Composite使得用户对单个对象和组合对象的使用具有一致性。

适用性:1. 你想表示对象的部分-整体层次结构。 2. 你希望用户忽略组合对象与单个对象的不同,用户将统一地使用组合结构中的所有对象。

以上文字虽然说得已经很明白了,但还是有点抽象。

举个栗子吧,我们都直到Java中的AWT与SWING中的那些组件,像Button,RadioButton,CheckBox等待,这些就相当于部件,也被称为树叶(对应下面代码的leaf),而Container是用在装载这些部件的,也叫做树枝。

最关键的部分就是树枝内部组合该接口,并且含有内部属性 List,里面放 Component

首先创建Component接口:

package com.structural.composite;public interface Component {
public void sayHello(); public void sayGoodbye();}

然后上面的接口写一个实现:

package com.structural.composite;import java.util.ArrayList;import java.util.List;public class Composite implements Component {
List
components = new ArrayList
(); @Override public void sayHello() { for (Component component : components) { component.sayHello(); } } @Override public void sayGoodbye() { for (Component component : components) { component.sayGoodbye(); } } public void add(Component component) { components.add(component); } public void remove(Component component) { components.remove(component); } public List
getComponents() { return components; } public Component getComponent(int index) { return components.get(index); }}

然后呢,实现一下叶子类。

package com.structural.composite;public class Leaf implements Component {
String name; public Leaf(String name) { this.name = name; } @Override public void sayHello() { // TODO Auto-generated method stub System.out.println(name + " leaf says hello"); } @Override public void sayGoodbye() { // TODO Auto-generated method stub System.out.println(name + " leaf says goodbye"); }}
package com.structural.composite;public class TestCompositePattern {
public static void main(String[] args) { // TODO Auto-generated method stub Leaf leaf1 = new Leaf("Bob"); Leaf leaf2 = new Leaf("Fred"); Leaf leaf3 = new Leaf("Sue"); Leaf leaf4 = new Leaf("Ellen"); Leaf leaf5 = new Leaf("Joe"); Composite composite1 = new Composite(); composite1.add(leaf1); composite1.add(leaf2); Composite composite2 = new Composite(); composite2.add(leaf3); composite2.add(leaf4); Composite composite3 = new Composite(); composite3.add(composite1); composite3.add(composite2); composite3.add(leaf5); System.out.println("Calling 'sayHello' on leaf1"); leaf1.sayHello(); System.out.println("\nCalling 'sayHello' on composite1"); composite1.sayHello(); System.out.println("\nCalling 'sayHello' on composite2"); composite2.sayHello(); System.out.println("\nCalling 'sayGoodbye' on composite3"); composite3.sayGoodbye(); }}

输出:

Calling 'sayHello' on leaf1Bob leaf says helloCalling 'sayHello' on composite1Bob leaf says helloFred leaf says helloCalling 'sayHello' on composite2Sue leaf says helloEllen leaf says helloCalling 'sayGoodbye' on composite3Bob leaf says goodbyeFred leaf says goodbyeSue leaf says goodbyeEllen leaf says goodbyeJoe leaf says goodbye

最后还是来一张UML图

这里写图片描述

参考文献

[1]《设计模式——可复用面向对象软件的基础》,Erich Gramma,Richard Helm,Ralph Johnson,John Vlossides。机械工业出版社

[2]
[3]

你可能感兴趣的文章
Android中的Binder(二)
查看>>
Framework之View的工作原理(一)
查看>>
Web应用架构
查看>>
设计模式之策略模式
查看>>
深究Java中的RMI底层原理
查看>>
用idea创建一个maven web项目
查看>>
Kafka
查看>>
9.1 为我们的角色划分权限
查看>>
维吉尼亚之加解密及破解
查看>>
DES加解密
查看>>
TCP/IP协议三次握手与四次握手流程解析
查看>>
PHP 扩展开发 : 编写一个hello world !
查看>>
inet_ntoa、 inet_aton、inet_addr
查看>>
用模板写单链表
查看>>
用模板写单链表
查看>>
链表各类操作详解
查看>>
C++实现 简单 单链表
查看>>
数据结构之单链表——C++模板类实现
查看>>
Linux的SOCKET编程 简单演示
查看>>
正则匹配函数
查看>>