设计模式(3)--对象结构(5)--外观

1. 意图

为子系统中的一组接口提供一个一致的界面,Facade模式定义了一个高层接口,这个接口使得

这一子系统更加容易使用。

2. 两种角色

子系统(Subsystem)、外观(Facade)

3. 优点

3.1 对客户屏蔽了子系统组件,减少了客户处理的对象数目

3.2 实现了子系统与客户之间的松耦合关系

3.3 如果需要,仍然可以使用子系统类

4. 缺点

N/A

5. 相关模式

5.1 抽象工厂模式可以和外观模式一起使用来提供一个接口。

5.2 Mediator的目的是对同事之间的任意通讯进行抽象,同事对象通过中介者与其他对象通信。

Façade的目的是对子系统对象的接口进行抽象,使更容易使用;它不定义新功能,子系统也

不知道Façade存在。

6. 代码示意(C++)
cpp 复制代码
#pragma once
#include<iostream>
#include <string>
using namespace std;

class SubSysOne
{
public:
	void MethodOne()
	{
		cout << "SubSysOne:方法一" << endl;
	}
};

class SubSysTwo
{
public:
	virtual void MethodTwo() = 0;
};
class ConcreteSubSysTwo : public SubSysTwo
{
public:
	virtual void MethodTwo()
	{
		cout << "ConcreteSubSysTwo:方法二" << endl;
	}
};

class Facade
{
public:
	void MethodOne()
	{
		SubSysOne* pSubSysOne = new SubSysOne;
		pSubSysOne->MethodOne();
		delete pSubSysOne;
	}
	void MethodTwo()
	{
		SubSysTwo* pSubSysTwo = new ConcreteSubSysTwo;
		pSubSysTwo->MethodTwo();
		delete pSubSysTwo;
	}
};
cpp 复制代码
#include "Facade.h"
int main() {
	Facade* pFacade = new Facade;
	pFacade->MethodOne();
	pFacade->MethodTwo();

	delete pFacade;
	return 0;
}

运行结果:

6.1 客户只需针对Facade编程(3.1)

6.2 客户仍然可以直接使用子系统类(3.3)

相关推荐
喝拿铁写前端1 天前
Vue 实战:构建灵活可维护的菜单系统
前端·vue.js·设计模式
VisuperviReborn1 天前
打造自己的前端监控---前端流量监控
前端·设计模式·架构
BUG收容所所长1 天前
发布订阅模式 vs 观察者模式:它们真的是一回事吗?
前端·javascript·设计模式
探索为何1 天前
Transformer:从神坛到笑坛的华丽转身
设计模式·程序员·代码规范
AlenLi1 天前
JavaScript - 单例模式的几种简单实现方式
设计模式
心月狐的流火号1 天前
观察者模式解析与Spring事件机制
spring·设计模式
用户6120414922131 天前
C语言做的汽车线路模拟查询系统
c语言·后端·设计模式
#六脉神剑2 天前
接口请求的后台发起确认
低代码·设计模式·产品运营·mybuilder
二闹2 天前
高效开发秘籍:CRUD增强实战
后端·设计模式·性能优化
aiwery2 天前
深入理解React hooks:从设计初衷到自定义Hook指南
前端·设计模式