设计模式学习系列9 外观模式Facade
1.概述
自己卖了一辆越野自行车,但毕竟不是自己定制的,买回来之后可能需要更改一下脚蹬,座皮,里程计数器或者刹车系统,假如将自行车看做一个整体系统,对我们而言使用的是自行车,然后我们对自己车构件的修改对于我们的使用而言并没有什么影响。在软件里面一个大型系统需要分割为多个不同的子系统组成,可能回派分给不同的人去完成,对于我们整个系统顶层实现而言,我们只用关注子系统提供的接口即可,而不用去处理子系统的细节,并且尽量去降低每个子系统之间的关系对于后面的扩展肯定是更好的。从面向对象的角度而言,我们需要每个子系统之间的耦合行最低并且子系统的更改尽量不会去更改顶层代码,这时候我们就需要外观模式来完成这个人物。
2.外观模式定义
外观模式定义为子系统中的一组接口提供一个一致的界面, 这个接口使得这一子系统更加容易使用。引入外观角色之后,用户只需要直接与外观角色交互,用户与子系统之间的复杂关系由外观角色来实现,从而降低了系统的耦合度。

(1)适用情况
- 构件一个层次的系统时,子系统接口通过外观模式定义
- 为复杂系统提供一个简单的接口,满足子系统变化对顶层结构无影响
- 客户端与抽象类之间依赖性太强
(2)优缺点
优点:
- 减少客户端与子系统之间的耦合度,减少客户端处理的数目,子系统的变化不会影响到客户端的代码。
- 降低模块之间的编译依赖性
缺点:
- 只能处理单一的子系统,如果引入新的子系统,则需要修改整个客户端代码。
3.C++实现
//外观模式
#include "iostream"
using namespace std;
class SubSystem1
{
public:
void Action()
{
cout << "子系统1" << endl;
}
};
class SubSystem2
{
public:
void Action()
{
cout << "子系统2" << endl;
}
};
class Facede
{
private:
SubSystem1* pSubSystem1 ;
SubSystem2* pSubSystem2 ;
public:
Facede():pSubSystem1(0),pSubSystem2(0)
{
pSubSystem1 = new SubSystem1 ;
pSubSystem2 = new SubSystem2 ;
}
~Facede()
{
if(pSubSystem1 != 0)
delete pSubSystem1 ;
if(pSubSystem2 != 0)
delete pSubSystem2 ;
}
void Action()
{
cout << "系统执行" << endl;
pSubSystem1->Action();
pSubSystem2->Action();
}
};
int main()
{
Facede* pFacede = new Facede ;
pFacede->Action();
delete pFacede;
return 1;
}
4.扩展:抽象外观模式
外观模式中需要对子系统进行删除,增加,修改的时候就需要对外观接口以及里面的子类进行修改,遮掩归咎违背了面向对象的“开放闭合原则”,抽象外观模式可以避免这个问题的问题。 抽象外观模式增减一个抽象外观的基类,当对当前的子系统进行修改时可通过新的外观模式类来实现新的接口。

图中增加了新的SubsystemC子类,这个时候不用去修改原有接口,只用重新增加一个新的接口接口。
5参考
http://blog.csdn.net/hguisu/article/details/7533759
http://blog.csdn.net/lovelion/article/details/8259789
设计模式学习系列9 外观模式Facade的更多相关文章
- 设计模式学习系列6 原型模式(prototype)
原型模式(prototype)用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象.允许一个对象再创建另外一个新对象的时候根本无需知道任何创建细节,只需要请求圆形对象的copy函数皆可. 1 ...
- 设计模式(九)外观模式Facade(结构型)
设计模式(九)外观模式Facade(结构型) 1. 概述 外观模式,我们通过外观的包装,使应用程序只能看到外观对象,而不会看到具体的细节对象,这样无疑会降低应用程序的复杂度,并且提高了程序的可维护性. ...
- 设计模式(二)-- 外观模式(Facade)
设计模式(二) 外观模式(Facade) 为了解决子系统外部的客户端在使用子系统的时候,既能简单地使用这些子系统内部的模块功能,而又不用客户端去与子系统内部的多个模块交互的问题. 为子系统中的一组接口 ...
- 设计模式系列之外观模式(Facade Pattern)——提供统一的入口
说明:设计模式系列文章是读刘伟所著<设计模式的艺术之道(软件开发人员内功修炼之道)>一书的阅读笔记.个人感觉这本书讲的不错,有兴趣推荐读一读.详细内容也可以看看此书作者的博客https:/ ...
- 【转】设计模式(九)外观模式Facade(结构型)
设计模式--外观模式Facade(结构型): 1. 概述 外观模式,我们通过外观的包装,使应用程序只能看到外观对象,而不会看到具体的细节对象,这样无疑会降低应用程序的复杂度,并且提高了程序的可维护性. ...
- Java设计模式菜鸟系列(九)外观模式建模与实现
转载请注明出处:http://blog.csdn.net/lhy_ycu/article/details/39805735 外观模式(Facade):是为了解决类与类之间的依赖关系的,像spring一 ...
- 研磨设计模式学习笔记2--外观模式Facade
需求:客户端需要按照需求,执行一个操作,操作包括一个系统中的3个模块(根据配置选择是否全部执行). 外观模式优点: 客户端无需知道系统内部实现,,只需要写好配置文件,控制那些模块执行,简单易用. 外观 ...
- Headfirst设计模式的C++实现——外观模式(Facade)
light.h #ifndef _LIGHT_H_ #define _LIGHT_H_ #include <iostream> class LIGHT { public: void dim ...
- Java设计模式(11)外观模式(Facade模式)
外观模式(Facade)的定义:为子系统中的一组接口提供一个一致的界面. Facade一个典型应用就是数据库JDBC的应用,如下例对数据库的操作: public class DBCompare { C ...
随机推荐
- [译]ASP.NET 性能监控
概述:在性能测试中性能监视器是非常强大的工具,本文主要简述了几个关键的计数器和相关的阈值. 监控性能计数器 很多的性能计数器在性能调优中是非常重要的,由于性能计数器太多,很多人不知道选择那些计数器. ...
- 怎么在手机上查看sqlite db
在 从 百度应用 下载“SQLite编辑器(SQLite Editor)” 安装到手机上.前体是 手机已经Root(可以用360一键Root软件进行root).
- Servlet跳转方式
servlet之间的跳转,有两种方式: 1.redirect方式,是新的请求,数据不相同 2.forward方式是同一个请求,数据相同
- 合成模式(Composite)-结构型
原理 合成模式属于对象的结构模式,有时又叫做“部分——整体”模式.合成模式将对象组织到树结构中,可以用来描述整体与部分的关系.合成模式可以使客户端将单纯元素与复合元素同等看待. 有时候又叫做部分-整体 ...
- SU sugabor命令学习
不足之处,欢迎批评指正.
- 绑定GoDaddy域名到OpenShift应用
一.申请GoDaddy域名 二.托管OpenShift应用 三.绑定www.mydomain.com 四.重定向mydomin.com到www.mydomain.com 五.It's go time ...
- ember.js:使用笔记8 加载测试与集成测试
emberjs使用的测试工具为qunit.js: 加载:将runner.js添加到Index.html:大致内容: if (window.location.search.indexOf("? ...
- React-Native 之控件布局
Nodejs 一度将前端JS 推到了服务器端,而15年FB的React-Native RN再一次将JS 推到了移动端的开发浪潮中.RN的优势这里不再重复,它是我们这些习惯了服务端.web端开发,而又不 ...
- CodeForces Round 200 Div2
这次比赛出的题真是前所未有的水!只用了一小时零十分钟就过了前4道题,不过E题还是没有在比赛时做出来,今天上午我又把E题做了一遍,发现其实也很水.昨天晚上人品爆发,居然排到Rank 55,运气好的话没准 ...
- 【wikioi】2216 行星序列(线段树)
http://wikioi.com/problem/2216/ 这题太让我感动了QAQ,让我找到了我一直以来写线段树的错误!!!! 就是,pushdown一定要放在最前面!要不然顺序会错.也就是说,当 ...