门面模式
定义
为子系统中的一组接口提供一个一致的界面,Facade模式定义了一个高层接口,这个接口使得子系统更加容易使用。
- Facade
- 知道哪些子系统类负责处理请求
- 将客户的请求代理给适当的子系统对象
- Subsytem classes
- 实现子系统的功能
- 处理有facade对象指派的任务
- 没有facade的任何相关信息,即没有执行facade的指针。
使用场景
- 当你要为一个复杂子系统提供一个简单接口时,子系统往往因为不断演化而变得越来越复杂。大多数模式使用时都会产生更多更小的类。这使得子系统更具可重用性,也更容易对子系统进行定制,但这也给那些不需要定制子系统的用户带来一些使用上的困难。Facade可以提供一个简单的缺省视图,这一视图对大多数用户来说已经足够,而那些需要更多的可定制的用户可以越过facade层。
- 客户程序与抽象类的实现部分之间存在很大的依赖性。在引入facade将这个子系统与客户以及其他的子系统分离,可以提高系统的独立性和可移植性。
- 当你需要构建一个层次结构的子系统时,使用facade模式定义子系统每层的入口点,如果子系统之间是相互依赖的,你可以让他们仅通过facade进行通信,从而简化了它们之间的依赖关系。
优缺点
- 降低客户-子系统之间的耦合度
- 公共子系统类与私有子系统类
实例
- 上一篇 装饰器模式
- 下一篇 工厂(简单工厂、工厂方法、抽象工厂)