结构型模式——门面(Facade)
问题背景
当需要为一个复杂的系统提供简单的接口时,考虑使用门面。现有一个编译器,由Lexer,Parser,Token等类组成,内部结构比较复杂。但编译器完成的唯一功能就是编译源代码,用户大多数情况下也不需要定制像开启/关闭指针、开启/关闭优化之类的功能。
解决方案
提供一个高层接口,这个接口包含系统的基本功能;系统内部的类同样会暴露给外界,以提供定制功能。当用户只是想简单地使用系统时,则通过门面;当用户希望使用系统的复杂功能时,则可以越过门面直接访问系统内部。
门面模式和其他设计模式有点不同,它的粒度比较大,以系统为单位进行描述,所以无法像其他模式一样给出具体的类图,只能简单给出一个概念图:
效果
- 提供两种使用方式,同时具备易用性和灵活性。
- 隐藏系统内部的实现细节。
相关模式
- 抽象工厂:可以用抽象工厂创建多个门面实现来提供系统的多种常用配置。
- 中介:门面和中介都起到了辅助降低整个系统复杂度的作用,但门面是降低了使用者和被使用者之间的耦合度,中介是降低了所有子系统间的耦合度。
- 单例:门面通常被设计成单例类。