前面介绍的适配器模式讲的是如何将一个接口转换成客户所需要的另一个接口,它的目的在于

解决接口的不兼容性问题。现在这里有这样一个模式,它的目的在于如何简化接口,它可以将多个类的复杂的一切隐藏在背后,只显露

出一个干净美观的外观。

晚上睡觉之前,你总是喜欢看电视,在你进入卧室的时候你需要完成以下几个步骤:打开电灯、打开空调、放心银幕(假如你家

有)、打开电视通过这么些繁琐的步骤后你终于可以看电视了,但是你要睡觉了呢?又要去进行繁琐的关闭动作。这里你就需要一个外观

模式了,通过实现一个更加合理的接口外观类将这些动作都包装起来,实现一键“看电视”、一键“关电视”。这就是外观模式的动机

一、模式定义

所谓外观模式就是提供一个统一的接口,用来访问子系统中的一群接口。

外观模式定义了一个高层接口,让子系统更容易使用。如下图,是使用外观模式后将子系统的使用变得更加简单。

在引入外观模式后,客户只需要与外观角色打交道,客户与子系统的复杂关系有外观角色来实现,从而降低了系统的耦合度。

 二、模式结构

外观模式包含如下两个角色:

Facade: 外观角色

SubSystem:子系统角色

       三、模式实现

场景就是上面那个“睡觉看电视”的场景。

实例的UML图

首先是四个组件(电视、电灯、空调、银幕)

public class Television {
public void on() {
System.out.println("打开了电视....");
} public void off() {
System.out.println("关闭了电视....");
}
}
public class Light {
public void on() {
System.out.println("打开了电灯....");
} public void off() {
System.out.println("关闭了电灯....");
}
}
public class AirCondition {
public void on() {
System.out.println("打开了空调....");
} public void off() {
System.out.println("关闭了空调....");
}
}
public class Screen {
public void up() {
System.out.println("升起银幕....");
} public void down() {
System.out.println("下降银幕....");
}
}
    然后是比较强大、干净、美观的外观
public class WatchTvSwtichFacade {
Light light;
AirCondition ac;
Television tv;
Screen screen; public WatchTvSwtichFacade(Light light, AirCondition ac, Television tv, Screen screen) {
this.light = light;
this.ac = ac;
this.tv = tv;
this.screen = screen;
} public void on() {
light.on(); //首先开灯
ac.on(); //然后是打开空调
screen.down(); //把银幕降下来
tv.on(); //最后是打开电视
} public void off() {
tv.off(); //首先关闭电视机
screen.up(); //银幕升上去
ac.off(); //空调关闭
light.off(); //最后关灯
}
}

客户端

public class Client {
public static void main(String[] args) {
//实例化组件
Light light = new Light();
Television tv = new Television();
AirCondition ac = new AirCondition();
Screen screen = new Screen(); WatchTvSwtichFacade watchTv = new WatchTvSwtichFacade(light, ac, tv, screen); watchTv.on();
System.out.println("--------------可以看电视了.........");
watchTv.off();
System.out.println("--------------可以睡觉了...........");
}
}

运行结果

打开了电灯....
打开了空调....
下降银幕....
打开了电视....
--------------可以看电视了.........
关闭了电视....
升起银幕....
关闭了空调....
关闭了电灯....
--------------可以睡觉了...........

  

从上面的使用通过使用外观模式,客户可以非常方便的实现比较复杂的功能。

         四、模式优缺点

优点

  1、引入外观模式,是客户对子系统的使用变得简单了,减少了与子系统的关联对象,实现了子系统与客户之间的松耦合关系。

     2、只是提供了一个访问子系统的统一入口,并不影响用户直接使用子系统类

3、降低了大型软件系统中的编译依赖性,并简化了系统在不同平台之间的移植过程

         缺点

    1、不能很好地限制客户使用子系统类,如果对客户访问子系统类做太多的限制则减少了可变性和灵活性

           2、在不引入抽象外观类的情况下,增加新的子系统可能需要修改外观类或客户端的源代码,违背了“开闭原则”

五、使用场景

         1、当要为一个复杂子系统提供一个简单接口时可以使用外观模式。

2、客户程序与多个子系统之间存在很大的依赖性。引入外观类将子系统与客户以及其他子系统解耦,可以提高子系统的独立性和

可移植性

         六、模式总结

         1、  外观模式的主要优点就在于减少了客户与子系统之间的关联对象,使用客户对子系统的使用变得简单了,也实现了客户与子

系统之间的松耦合关系。它的缺点就在于违背了“开闭原则”。

          2、  如果需要实现一个外观模式,需要将子系统组合进外观中,然后将工作委托给子系统执行。

设计模式:门面模式(Facade)的更多相关文章

  1. 说说设计模式~门面模式(Facade)

    返回目录 门面模式(Facade)属于结构型模式的一种,它符合面向对象的封装原则,但又不符合开闭原则,呵呵,今天我们主要说它的优点,不谈缺点. 定义 门面模式,是指提供一个统一的接口去访问多个子系统的 ...

  2. 外观模式 门面模式 Facade 结构型 设计模式(十三)

    外观模式(FACADE) 又称为门面模式   意图 为子系统中的一组接口提供一个一致的界面 Facade模式定义了一个高层接口,这一接口使得这一子系统更加易于使用. 意图解析 随着项目的持续发展,系统 ...

  3. linkin大话设计模式--门面模式

    linkin大话设计模式--门面模式 随着系统的不断改进和开发,他们会变得越来越复杂,系统会生成大量的类,这使得程序的流程更加难以理解.门面模式可以为这些类提供一个简易的接口,从而简化访问这些类的复杂 ...

  4. 大熊君说说JS与设计模式之(门面模式Facade)迪米特法则的救赎篇------(监狱的故事)

    一,总体概要 1,笔者浅谈 说起“门面”这个设计模式其实不论新老程序猿都是在无意中就已经运用到此模式了,就像我们美丽的JS程序员一样不经意就使用了闭包处理问题, function Employee(n ...

  5. 设计模式——门面模式(Facade)

    要想正确理解设计模式,首先必须明白它是为了解决什么问题而提出来的. 设计模式学习笔记 --Shulin 转载请注明出处:http://blog.csdn.net/zhshulin 1.概念 门面模式是 ...

  6. 24种设计模式--门面模式【Facade Pattern】

    大家都写过纸质的信件吧,比如给女朋友写情书什么的,写信的过程大家都还记得吧,先写信的内容,然后写信封,把信放到信封中,封好,投递到信箱中进行邮递,这个过程还是比较简单的,虽然简单,这四个步骤都是要跑的 ...

  7. 设计模式 - 门面模式(Facade Pattern,也叫外观模式)

    简介 场景 将系统划分为若干个子系统有利于降低系统的复杂性,但是这会增加调用者的复杂性.通过引入 Facade 可以对调用者屏蔽系统内部子系统的细节. Java 中有多个日志库,例如 log4j.lo ...

  8. 设计模式在实际业务应用中的介绍之3——外观或门面模式Facade对AOP装配业务工厂的应用

    在C#中实现的基于外观或门面模式打造的业务应用案例 以前一直没有想过写一些东西来把项目中用到的知识点及技术实现做一个归纳整理并分享出来.现在打算逐渐的把项目中的一些东西整理并分享出来,与大家共勉! 外 ...

  9. Tomcat源代码-门面模式(Facade)

    从Tomcat源码提炼出设计模式-门面设计模式: 概念 外部访问内部,耦合度增加,不利于扩展.而门面模式在内部基础上进行再度封装,只提供外部想要的方法.这时访问方式由“外部---内部”变为了“外部-- ...

  10. c++ 门面模式(Facade)

    门面模式是比较常用的一种设计模式,我们可能在无意中就会使用,门面模式就是用一个门面类来处理子系统的复杂关系,门面类简单的Api接口供客户端调用.用一个简单的演播室来表示. #include <i ...

随机推荐

  1. noi.ac #529 神树的矩阵

    题目链接:戳我 当 \(max(n, m) \ge 3\) 时,可以如下构造: 考虑下面这样三个矩阵,红 + 蓝 − 绿得到的矩阵是一个第一行和最后一行全是 1,其他地方全是 0 的矩阵. 那么如果需 ...

  2. Python基础之赋值运算符

    如下图所示,假设变量a = 10, b = 20

  3. CF762F Tree nesting

    题目连接 问题分析 可以给小树钦定一个根, \(Dp[i][j]\) 表示大树上的点 \(i\) 对应到小树上的点 \(j\) 的可能的方案数.然后每一步转移都是一个状压DP(将小树是否被匹配状压,然 ...

  4. sklearn3_svc分类器预测

    python机器学习-乳腺癌细胞挖掘(博主亲自录制视频) https://study.163.com/course/introduction.htm?courseId=1005269003&u ...

  5. LC 890. Find and Replace Pattern

    You have a list of words and a pattern, and you want to know which words in words matches the patter ...

  6. Dialog 对话框

    在保留当前页面状态的情况下,告知用户并承载相关操作. 基本用法 Dialog 弹出一个对话框,适合需要定制性更大的场景. 需要设置visible属性,它接收Boolean,当为true时显示 Dial ...

  7. 爬虫 lxml 模块

    Xpath 在 XML 文档中查找信息的语言, 同样适用于 HTML 辅助工具 Xpath Helper Chrome插件  快捷键 Ctrl + shift + x XML Quire xpath ...

  8. 从Docker在Linux和Windows下的区别简单理解Docker的层次结构

    上篇文章我们成功在Windows下安装了Docker,输出了一个简单的Hello World程序.本文中我们将利用Docker已有的云端镜像training/webapp来发布一个简单Python的W ...

  9. 阶段3 3.SpringMVC·_05.文件上传_1 文件上传之上传原理分析和搭建环境

    分成几个部分 里面可能就包含文件上传的值 提交方式要改成post 第三个就是提供一个input file的文件选择域 新建项目 新建一个项目 当前项目没有父工程 跳过联网下载 改成02 构建 编译和目 ...

  10. 阶段3 3.SpringMVC·_03.SpringMVC常用注解_2 RequestBody注解

    拿整个请求体的数据