设计模式-结构型-外观模式(门面模式,Facade)
为程序库,框架或其他复杂类提供一个简单的接口。
文章目录
外观模式
提供了一个统一的接口,用来访问子系统中的一群接口。比如医院的导诊台,微服务架构的网关。。。
一、应用场景
- 为复杂的模块或子系统提供一个简介的供外界访问的接口
- 提高子系统的独立性
- 隔离客户端与子系统的直接交互,防止代码污染。
二、角色说明
- 外观角色(facade):是系统对外的统一接口。
- 子系统角色(SubSystem):可以同时有一个或多个子系统,每个子系统都不是一个单独的类,而是一个类的集合,子系统不知道外观角色的存在,对子系统而言,外观角色只是一个客户端。
三、使用步骤
1.添加SubSystem子系统功能
代码如下(示例):
public class InternalMedicineSubject
{
public void Visit()
{
Console.WriteLine("进入内科就诊");
}
}
public class SurgerySubject
{
public void Visit()
{
Console.WriteLine("进入外科就诊");
}
}
public class OrthoPaedicsSubject
{
public void Visit()
{
Console.WriteLine("进入骨科就诊");
}
}
2.添加外观类
代码如下(示例):外观类整合
public class HospitalSubjectFacade
{
private readonly InternalMedicineSubject ims = new InternalMedicineSubject();
private readonly SurgerySubject ss = new SurgerySubject();
private readonly OrthoPaedicsSubject ops = new OrthoPaedicsSubject();
public HospitalSubjectFacade() {
Console.WriteLine("欢迎来到分诊大厅");
}
public void imsVisit()
{
ims.Visit();
}
public void ssVisit()
{
ss.Visit();
}
public void opsVisit()
{
ops.Visit();
}
}
3.Client
代码如下(示例):客户端调用示例
public class MenuSubjectClient
{
public void MenuSubject() {
HospitalSubjectFacade hsf = new HospitalSubjectFacade();
hsf.imsVisit();
hsf.opsVisit();
hsf.ssVisit();
}
}
四、外观模式扩展
1.优点
- 简化了调用过程
- 减少系统依赖,达到低耦合
- 层次划分清晰,提高代码安全性
- 遵循迪米特法则
2.缺点
- 当增加子系统和扩展子系统行为时,可能容易带来未知风险
- 不符合开闭原则
- 某些情况下,可能违背了单一职责的原则(外观类明显)。
总结
`外观模式中外观类时统一对子系统行为的整理总结。使调用则不用再关心子系统,可以直接调用外观类达到相同的效果,实现了调用则和子系统的解耦,容易扩展,层级关系也更清晰。