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

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

组合模式描写叙述了怎样将容器对象和叶子对象进行递归组合,使得用户在使用时无须对它们进行区分,能够一致地对待容器对象和叶子对象,这就是组合模式的模式动机。

1、模式定义

组合模式(Composite Pattern):组合多个对象形成树形结构以表示“总体-部分”的结构层次。组合模式对单个对象(即叶子对象)和组合对象(即容器对象)的使用具有一致性。

组合模式又能够称为“总体-部分”(Part-Whole)模式,属于对象的结构模式,它将对象组织到树结构中,能够用来描写叙述总体与部分的关系。

2、模式结构

组合模式包括例如以下角色:

Component: 抽象构件
Leaf: 叶子构件
Composite: 容器构件
Client: 客户类

3、模式分析

组合模式的关键是定义了一个抽象构件类,它既能够代表叶子,又能够代表容器,而client针对该抽象构件类进行编程,无须知道它究竟表示的是叶子还是容器,能够对其进行统一处理。

同一时候容器对象与抽象构件类之间还建立一个聚合关联关系,在容器对象中既能够包括叶子,也能够包括容器,以此实现递归组合,形成一个树形结构。

典型的抽象构件角色代码:

public abstract class Component

{
public abstract void add(Component c);
public abstract void remove(Component c);
public abstract Component getChild(int i);
public abstract void operation(); 

典型的叶子构件角色代码:

public class Leaf extends Component

{
public void add(Component c)
{ //异常处理或错误提示 }
public void remove(Component c)
{ //异常处理或错误提示 }
public Component getChild(int i)
{ //异常处理或错误提示 }
public void operation()
{
//实现代码

public class Composite extends Component

{
private ArrayList list = new ArrayList();
public void add(Component c)
{
list.add(c);
}
public void remove(Component c)
{
list.remove(c);
}
public Component getChild(int i)
{
(Component)list.get(i);
}
public void operation()
{
for(Object obj:list)
{
((Component)obj).operation();
}
}

模式适用环境

须要表示一个对象总体或部分层次。在具有总体和部分的层次结构中,希望通过一种方式忽略总体与部分的差异,能够一致地对待它们。

让客户可以忽略不同对象层次的变化。client可以针对抽象构件编程,无须关心对象层次结构的细节。
对象的结构是动态的而且复杂程度不一样,但客户须要一致地处理它们。

转载地址:http://wccta.baihongyu.com/

你可能感兴趣的文章
【转载】每个程序员都应该学习使用Python或Ruby
查看>>
PHP高级编程之守护进程,实现优雅重启
查看>>
PHP字符编码转换类3
查看>>
rsync同步服务配置手记
查看>>
http缓存知识
查看>>
Go 时间交并集小工具
查看>>
iOS 多线程总结
查看>>
webpack是如何实现前端模块化的
查看>>
TCP的三次握手四次挥手
查看>>
关于redis的几件小事(六)redis的持久化
查看>>
webpack4+babel7+eslint+editorconfig+react-hot-loader 搭建react开发环境
查看>>
Maven 插件
查看>>
初探Angular6.x---进入用户编辑模块
查看>>
计算机基础知识复习
查看>>
【前端词典】实现 Canvas 下雪背景引发的性能思考
查看>>
大佬是怎么思考设计MySQL优化方案的?
查看>>
<三体> 给岁月以文明, 给时光以生命
查看>>
Android开发 - 掌握ConstraintLayout(九)分组(Group)
查看>>
springboot+logback日志异步数据库
查看>>
Typescript教程之函数
查看>>