设计模式 结构型模式 - 外观模式(五)

外观模式是一种设计模式,旨在为复杂的子系统提供一个统一的访问接口,减少客户端与子系统间的直接交互,提高系统的可维护性和可扩展性。它在系统分层结构中扮演关键角色,通过定义外观角色和子系统角色,降低了模块间的依赖。此模式在实际应用中,如在构建分层结构系统时,可以作为各层的入口点,使系统更易于使用和理解。
摘要由CSDN通过智能技术生成

一、概述

定义:

又名门面模式,是一种通过为多个复杂的子系统提供一个一致的接口,而使这些子系统更加容易被访问的模式。该模式对外有一个统一的接口,外部应用程序不用关心内部子系统的具体的细节,这样会大大降低应用程序的复杂度,提高了程序的可维护性。

外观(Facade)模式是“迪米特法则”的典型应用。

二、结构

外观(Facade)模式包含以下主要角色:

(1)外观(Facade)角色:为多个子系统对外提供一个共同的接口。

(2)子系统(Sub System)角色:实现系统的部分功能,客户可以通过外观角色访问它。

三、案例

 

好处:

(1)降低了子系统与客户端之间的耦合度,使得子系统的变化不会影响调用它的客户类。

(2)对客户屏蔽了子系统组件,减少了客户处理的对象数目,并使得子系统使用起来更加容易。

缺点:

(1)不符合开闭原则,修改很麻烦。

四、使用场景

(1)对分层结构系统构建时,使用外观模式定义子系统中没层的入口点可以简化子系统之间的依赖关系。

(2)当一个复杂系统的子系统很多时,外观模式可以为系统设计一个简单的接口供外界访问。

(3)当客户端与多个子系统之间存在很大的联系时,引入外观模式可将它们分离,从而提高子系统的独立性和可移植性。

五、源码解析

为什么在此处使用外观模式呢?

定义 RequestFacade 类,分别实现 ServletRequest,同时定义私有成员变量 Request,并且方法的实现调用 Request 的实现。然后,将 RequestFacade 上转为 ServletRequest 传给 servlet 的 service 方法,这样即使在 servlet 中被下转为 RequestFacade,也不能访问私有成员变量对象中的方法。既用了 Request,又能防止其中方法被不合理的访问。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值