首页 > 代码库 > 设计模式(10) 外观模式(FACADE)

设计模式(10) 外观模式(FACADE)

问题聚焦:
    设计一个系统时,比较常见的做法是将它划分为若干个小的系统,互相协作,组成一个大的系统。
    那么,在设计这些小系统时,需要注意一些什么呢?
    外观模式为什么可以让子系统更加容易的使用呢?(最小化子系统之间的通信和相互依赖关系,即降低耦合度)
意图:
    为子系统中的一组接口提供一个一致的界面。Facade模式定义了一个高层接口,这个接口使得这一子系统更加容易使用。
动机:
    将一个系统划分为若干个子系统有利于降低系统的复杂性。
    一个常见的设计目标是使子系统间的通信和相互依赖关系达到最小。
    达到该目标的途径之一就是引入一个外观对象,它为子系统中较一般的设施提供了一个单一而简单的界面。
    其思想如下图所示:
    Demo:以编译器子系统的设计为例,说明外观模式的思想:
    子系统类划分:Scanner, Parser, ProgramNode, BytecodeStream, ProgramNodeBuilder
    要求:对普通用户提供一个高层的,单一而简单的编译子系统接口
              对高级专业的用户提供底层功能,可以直接访问具体的子系统类。
    设计:
    技术分享
    Compiler类(关键),其职责为两点:    
    1)为用户屏蔽子系统,提供一个高层的简单的使用接口;
    2)不完全隐藏实现编译功能的那些子系统类,使得少数懂的如何使用底层功能的人可以调用这些功能。

适用性:
在遇到以下情况使用Facade模式:
  • 为一个复杂子系统提供一个简单接口。
  • 客户程序与抽象类的实现部分之间存在很大的依赖性。
  • 当你需要构件一个层次结构的子系统时,使用facade模式定义子系统中每层的入口点。如果子系统之间是相互依赖的,可以让它们仅通过facade进行通讯,从而简化了它们之间的依赖关系。

结构:

 

    技术分享

设计模式(10) 外观模式(FACADE)