php八大设计模式之桥接模式
一个抽象产生多种具体的实现方式,单纯的通过子类继承会有子类爆炸(过多的子类产生)的现象,系统需要它们之间进行动态耦合。
面向过程:
<?php
header("content-type:text/html;charset=utf8");
/**
* 在一个网站中,我们都有给用户发通知消息的情况。比如有站内发送、 邮箱发送、及短信发送等等。
* 面向过程形式完成发送。
*/
//发送信息接口。
interface info{
public function send($to,$msg);
}
//站内方式发送。
class zn implements info{
public function send($to,$con){
echo "站内给:".$to." 内容是:".$con;
}
}
//邮箱方式发送。
class email implements info{
public function send($to,$con){
echo "email给:".$to." 内容是:".$con;
}
}
//短信方式发送。
class sms implements info{
public function send($to,$con){
echo "短信给:".$to." 内容是:".$con;
}
}
/**
* 可是如下还有分发送的级别呢?是不是又要继承出多个子类?
* 站内方式发送【普通】。
* class znInfo implements info{}
* 邮箱方式发送【普通】。
* class emailInfo implements info{}
* 短信方式发送【普通】。
* class smsInfo implements info{}
* ......
* .........
*
*/
?>
桥接模式:
<?php
header("content-type:text/html;charset=utf8");
/**
* 桥接模式完成发送。
* 虽然代码有些耦合,但是解决了子类爆炸(过多的现象)。
*/
//抽象的发送类。
abstract class info{
//
protected $send=null;
//获得
public function __construct($send){
$this->send=$send;
}
//加工短信内容方法。
abstract public function msg($content);
//发送信息方法。
public function send($to,$content){
$content=$this->msg($content);
$this->send->send($to,$content);
}
}
//站内发送方式。
class zn {
public function send($to,$con){
echo "站内给:".$to." 内容是:".$con;
}
}
//邮箱发送方式。
class email {
public function send($to,$con){
echo "email给:".$to." 内容是:".$con;
}
}
//短信发送方式。
class sms {
public function send($to,$con){
echo "sms给:".$to." 内容是:".$con;
}
}
//普通发送方式。
class commonInfo extends info{
public function msg($con){
return $con."【普通】";
}
}
//紧急发送方式。
class warnInfo extends info{
public function msg($con){
return $con."【紧急】";
}
}
//特急发送方式。
class dangerInfo extends info{
public function msg($con){
return $con."【特急】";
}
}
//实现发送功能。
/**
* 步骤是:
* 实例化一种发送方式,将实例化后的对象传给发送方式。
* 发送方式实现了抽象发送类,所以会先将当前对象赋给一个属性。
* 然后通过调用抽象发送类的 send ,去实现处理信息内容再发送。
*/
$common=new commonInfo(new zn());
$common->send("小王","回家啦");
echo '<hr>';
$common=new commonInfo(new sms());
$common->send("小王","回家啦");
?>
php八大设计模式之桥接模式的更多相关文章
- 乐在其中设计模式(C#) - 桥接模式(Bridge Pattern)
原文:乐在其中设计模式(C#) - 桥接模式(Bridge Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 桥接模式(Bridge Pattern) 作者:webabcd 介绍 ...
- java面试题之----jdbc中使用的设计模式(桥接模式)
1.JDBC(JavaDatabase Connectivity) JDBC是以统一方式访问数据库的API. 它提供了独立于平台的数据库访问,也就是说,有了JDBC API,我们就不必为访问Oracl ...
- php设计模式之桥接模式
php设计模式之桥接模式 一.概述 桥接模式:将两个原本不相关的类结合在一起,然后利用两个类中的方法和属性,输出一份新的结果. 其实就是讲不相关的东西通过类(本例中是SendInfo)结合在一起,从而 ...
- java设计模式7——桥接模式
java设计模式7--桥接模式 1.桥接模式介绍 桥接模式是将抽象部分与它的实现部分分离,使他们都可以独立的变化.它是一种对象结构型模式,又称为柄体模式或接口模式. 2.解决问题 2.1.将复杂的组合 ...
- C++设计模式-Bridge桥接模式
作用:将抽象部份与它的实现部份分离,使它们都可以独立地变化. 将抽象(Abstraction)与实现(Implementation)分离,使得二者可以独立地变化. 桥接模式号称设计模式中最难理解的模式 ...
- 设计模式之桥接模式(Bridge)
注:本文不属于原创,而是根据原文重新整理,原文是:我给媳妇解释设计模式:第一部分 设计模式不是基于理论发明的.相反,总是先有问题场景,再基于需求和情景不断演化设计方案,最后把一些方案标准化成“模式”. ...
- 【GOF23设计模式】桥接模式
来源:http://www.bjsxt.com/ 一.[GOF23设计模式]_桥接模式.多层继承结构.银行日志管理.管理系统消息管理.人力资源的奖金计算 未用桥接模式: package com.te ...
- js设计模式(3)---桥接模式
0.前言 看设计模式比较痛苦,一则是自己经验尚浅,不能体会到使用这些设计模式的益处:二则是不能很好把握使用这些设计模式的时机.所以这一部分看得断断续续,拖拖拉拉,为了了却这快心病,决定最近一口气看完几 ...
- [设计模式] 7 桥接模式 bridge
#include<iostream> using namespace std; class AbstractionImp { public: virtual ~AbstractionImp ...
随机推荐
- 一个比NPM更快更安全可靠的JavaScript包管理工具——Yarn
yarn安装: npm intall -g yarn 查看安装是否成功: yarn -v yarn常用的命令以及和npm的对照如下: 更详细的请查看官方文档
- Android自定义TabBar
转载请说明出处:http://www.sunhome.org.cn 我发现现在的移动开发界面都被iOS主导了,UI动不动设计出来的东西都是ios的风格,对于一个做Android的程序员来说甚是苦恼啊, ...
- MySQL学习(三)——Java连接MySQL数据库
1.什么是JDBC? JDBC(Java DataBase Connectivity)就是Java数据库连接,说白了就是用Java语言来操作数据库.原来我们操作数据库是在控制台使用SQL语句来操作数据 ...
- ASP.NET MVC 使用FluentScheduler做定时任务
源代码地址: https://github.com/fluentscheduler/FluentScheduler 使用NuGet安装FluentScheduler 这是我实际项目中用到的代码,也可看 ...
- JavaScript在不同环境下的全局对象
Node.js 环境下,全局的对象是 global. 浏览器下 window === self 而不是 global,今天才发现的,我惊呆了!
- shell简单监控脚本模板
#!/bin/bash host=127.0.0.1user=adminpassword='xx'port=6032x=0check_proxy(){v=$(mysql -N -u$user -p$p ...
- java 实现多线程 3种方式
java实现多线程可以有以下三种方式: (1)继承Thread 类,重写其run()方法: (2)实现Runnable接口,实现其run() 方法: (3) 实现Callable 接口,重写call( ...
- 基本数据类型(int,bool,str)
1.int bit_lenth() 计算整数在内存中占用的二进制码的长度 十进制 二进制 长度(bit_lenth()) 1 1 1 2 10 2 4 100 3 8 1000 4 16 10000 ...
- 移动端mete设置
<!DOCTYPE html> <!-- 使用 HTML5 doctype,不区分大小写 --> <html lang="zh-cmn-Hans"&g ...
- dropload上拉加载 下拉刷新
1.引入css.js <link rel="stylesheet" href=" ${pageContext.request.contextPath}/dist/d ...