定义
门面(外观)模式(Facade),他隐藏了系统的复杂性,并向客户端提供了一个可以访问系统的接口。这种类型的设计模式属于结构性模式。为子系统中的一组接口提供了一个统一的访问接口,这个接口使得子系统更容易被访问或者使用
使用场景:
- 为复杂的模块或子系统提供外界访问的模块
- 子系统相互独立
- 在层析结构中,可以使用外观模式定义系统的每一层的入口。
在后端开发中,一个常见的应用场景是:做多表数据更新时,业务逻辑层(Service层)对数据访问层(DAO层)的调用可能包含多个步骤,除此之外还要进行事务处理,最终统一对外提供一个update()方法,如此一来上层(如控制器Controller层)便可一步调用。软件模块应该只专注于各自擅长的领域,合理明确的分工模式才能更好地整合与共享资源。
优点:
- 松散耦合:使得客户端和子系统之间解耦,让子系统内部的模块功能更容易扩展和维护
- 简单易用:客户端根本不需要知道子系统内部的实现,或者根本不需要知道子系统内部的构成,它只需要跟Facade类交互即可。
- 更好的划分访问层次:有些方法是对系统外的,有些方法是系统内部相互交互的使用的。子系统把那些暴露给外部的功能集中到门面中,这样就可以实现客户端的使用,很好的隐藏了子系统内部的细节。
实例:
实例请参考:java设计模式之外观模式(门面模式)