(10)结构型模式——门面

结构型模式——门面(Facade)

问题背景

当需要为一个复杂的系统提供简单的接口时,考虑使用门面。现有一个编译器,由Lexer,Parser,Token等类组成,内部结构比较复杂。但编译器完成的唯一功能就是编译源代码,用户大多数情况下也不需要定制像开启/关闭指针、开启/关闭优化之类的功能。

解决方案

提供一个高层接口,这个接口包含系统的基本功能;系统内部的类同样会暴露给外界,以提供定制功能。当用户只是想简单地使用系统时,则通过门面;当用户希望使用系统的复杂功能时,则可以越过门面直接访问系统内部。

门面模式和其他设计模式有点不同,它的粒度比较大,以系统为单位进行描述,所以无法像其他模式一样给出具体的类图,只能简单给出一个概念图:
程序结构

效果

  1. 提供两种使用方式,同时具备易用性和灵活性。
  2. 隐藏系统内部的实现细节。

相关模式

  1. 抽象工厂:可以用抽象工厂创建多个门面实现来提供系统的多种常用配置。
  2. 中介:门面和中介都起到了辅助降低整个系统复杂度的作用,但门面是降低了使用者和被使用者之间的耦合度,中介是降低了所有子系统间的耦合度。
  3. 单例:门面通常被设计成单例类。
发布了27 篇原创文章 · 获赞 41 · 访问量 2081

猜你喜欢

转载自blog.csdn.net/DIAX_/article/details/104186457