设计模式 | 门面模式 Facade
时间:2022-07-22
本文章向大家介绍设计模式 | 门面模式 Facade,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
说明
门面模式又叫外观模式,这个设计模式也比较简单,比较容易理解,其实在我们正常编码中就已经写出了门面模式,但是我们并不知道这个写法是叫门面模式。
门面模式的定义:提供一个统一的接口去访问多个子系统的多个不同的接口,它为子系统中的一组接口提供一个统一的高层接口。使得子系统更容易使用。
简而言之就是请求一个接口 这个接口对应的操作是聚合了多个子系统的操作。这样使得子系统与客户之间是松耦合,更助于对象之间的依赖关系分层。
示例
我想做一个发送通知的操作,那么这个发送其实应该包含发送 短信、socket、推送等,使用者不需要知道这个东西,你只要提供一个门面给他调用即可 就能完成他想要的效果
<?php
/**
* Created by 憧憬.
*/
interface Message {
public function send($user);
}
/**
* 消息门面
* Class MessageFacade
*/
class MessageFacade
{
public $sms;
public $socket;
public $pusher;
public function __construct()
{
$this->sms = new Sms();
$this->socket = new Socket();
$this->pusher = new Pusher();
}
/**
* 发送消息
* @param $user
* @author: 憧憬
*/
public function send($user)
{
$this->sms->send($user);
$this->socket->send($user);
$this->pusher->send($user);
}
}
/**
* 发送短信
* Class Sms
*/
class Sms implements Message {
public function send($user)
{
echo '发送短信给'. $user;
}
}
/**
* 推送socket
* Class Socket
*/
class Socket implements Message {
public function send($user)
{
echo '发送socket给'. $user;
}
}
/**
* 推送消息
* Class Pusher
*/
class Pusher implements Message {
public function send($user)
{
echo '发送推送给'. $user;
}
}
(new MessageFacade())->send('憧憬 aoppp.com');
本文为作者原创,手码不易,允许转载,转载后请以链接形式说明文章出处。
- ASP.NET MVC 2 转换工具
- 使用Sysinternals工具定时休眠Windows Server 2008 R2
- Android中BroadcastReceiver广播
- 启用Windows 7/2008 R2 XPS Viewer
- Spring历史版本变迁和如今的生态帝国
- Android中Services之异步IntentService
- 使用GitHub搭建个人博客
- 这个用来玩儿游戏的算法,是谷歌收购DeepMind的最大原因
- asp.net安全检测工具 --Padding Oracle 检测
- Android中Services简析
- VUE 入门基础(2)
- VUE 入门基础(1)
- AndroidManifest.xml配置文件 android.theme大全权限设置Android Permission中英对照
- Reactive框架:简化异步及事件驱动编程
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- JNI函数加载
- CSS中的传统布局、多列布局、弹性伸缩布局及Emmet工具
- 数据分析可视化(四)|Pyecharts制作地图的几种方法评析
- tensorflow运行提示未编译使用SSE4.1,SSE4.2等问题的解决方法
- [手把手系列之二]实现多层神经网络
- 使用SystemVerilog简化FPGA中的接口
- 想用深度学习谱写自己的音乐吗?这篇指南来帮你!(附代码)
- 你不是说你会aop吗?
- 开源:推荐一个不错的离线IP地址定位库
- 武磊告别西甲!Python带你解读「全村的希望」武磊职业数据
- 谁在崛起,谁在没落?新一线城市竞争力盘点,用Python绘制动态图带你看懂!
- 两数相加
- 这样设置 IDEA,让你爽到飞起!
- Tensorflow基础入门十大操作总结
- Spring Boot 2.x基础教程:使用EhCache缓存集群