一、概述
橋接模式:將兩個原本不相關的類結合在一起,然后利用兩個類中的方法和屬性,輸出一份新的結果。
二、案例
1、模擬毛筆(轉)
需求:現在需要準備三種粗細(大中小),并且有五種顏色的比
如果使用蠟筆,我們需要準備3*5=15支蠟筆,也就是說必須準備15個具體的蠟筆類。而如果使用毛筆的話,只需要3種型號的毛筆,外加5個顏料盒,用3+5=8個類就可以實現15支蠟筆的功能。
實際上,蠟筆和毛筆的關鍵一個區別就在于筆和顏色是否能夠分離。即將抽象化(Abstraction)與實現化(Implementation)脫耦,使得二者可以獨立地變化"。關鍵就在于能否脫耦。蠟筆由于無法將筆與顏色分離,造成筆與顏色兩個自由度無法單獨變化,使得只有創建15種對象才能完成任務。而毛筆與顏料能夠很好的脫耦(比和顏色是分開的),抽象層面的概念是:"毛筆用顏料作畫",每個參與者(毛筆與顏料)都可以在自己的自由度上隨意轉換。
2、模擬企業分組發短信
需求:公司現在需要按分組(臨時工、正式工、管理層等)以多種形式(QQ、Email、微博等)給員工發送通知。
三、適用性
類的抽象以及它的實現都應該可以通過生成子類的方法加以擴充。通過使用Bridge模式對不同的抽象接口和實現部分進行組合,并分別對它們進行擴充。
不希望在抽象和它的實現部分之間有一個固定的綁定關系。
一個構件有多于一個的抽象化角色和實現化角色,系統需要它們之間進行動態耦合。
四、效果
Bridge模式使用“對象間的組合關系”解耦了抽象和實現之間固有的綁定關系,使得抽象和實現可以沿著各自的維度來變化。
所謂抽象和實現沿著各自維度的變化,即“子類化”它們,得到各個子類之后,便可以任意它們,從而獲得不同員工組和不同信息發送模式。
Bridge模式的應用一般在“兩個非常強的變化維度”,有時候即使有兩個變化的維度,但是某個方向的變化維度并不劇烈——換言之兩個變化不會導致縱橫交錯的結果,并不一定要使用Bridge模式。
Bridge模式將繼承關系轉換為組合關系,從而降低了系統間的耦合,減少了代碼編寫量。
```
<?php
abstract class Staff
{
abstract public function staffData();
}
class CommonStaff extends Staff
{
public function staffData()
{
return "小名,小紅,小黑";
}
}
class VipStaff extends Staff
{
public function staffData()
{
return "小星,小龍";
}
}
abstract class SendType
{
abstract public function send($to, $content);
}
class QQSend extends SendType
{
public function __construct()
{
}
public function send($to, $content)
{
return $content.'(To'.$to.'From QQ)<br>';
}
}
class SendInfo
{
protected $_level;
protected $_method;
public function __construct($level, $method)
{
$this->_level = $level;
$this->_method = $method;
}
public function sending($content)
{
$staffArr = $this->_level->staffData();
$result = $this->_method->send($staffArr, $content);
echo $result;
}
}
//客戶端調用
$info = new SendInfo(new VipStaff(), new QQSend());
$info->sending("哈哈哈");
```
- 空白目錄
- 安裝
- linux下安裝nginx
- linux下安裝php
- 調試
- windows 安裝wamp
- 常用源
- 類型
- Boolean布爾類型
- Integer整型
- Float浮點型
- String字符串
- Array數組
- Object對象
- Resource資源類型
- NULL
- Callback/Callable類型
- 類型轉換
- 變量
- 預定義變量
- 常量
- 魔術常量(預定義常量)
- 語法
- 運算符
- 流程控制
- 條件語句
- if
- else
- else if/elseif
- switch
- 循環語句
- while
- do-while
- for
- foreach
- break
- return
- continue
- require
- include
- require_once
- include_once
- 函數
- 內置函數
- 匿名函數
- 自定義函數
- 類與對象
- 屬性
- 聲明
- public
- protected
- private
- 類常量
- 方法
- 魔術方法
- __construct()
- __destruct()
- __call()
- __callStatic()
- __get()
- __set()
- __isset()
- __unset()
- __sleep()
- __wakeup()
- __toString()
- __invoke()
- __set_state()
- __clone()
- __debugInfo()
- 方法的調用
- ->(對象運算符)
- ::(范圍解析操作符)
- 設計模式
- 依賴注入
- call_user_func
- is_callable (
- 創建型模式
- 工廠方法模式
- 抽象工廠模式
- 單例模式
- 建造者模式
- 原型模式
- 結構性模式
- 適配器模式
- 裝飾器模式
- 代理模式
- 外觀模式
- 橋接模式
- 組合模式
- 享元模式
- 行為型模式
- 策略模式
- 模板方法模式
- 觀察者模式
- 迭代子模式
- 責任鏈模式
- 命令模式
- 備忘錄模式
- 訪問者模式
- 中介者模式
- 解釋器模式
- 六大原則
- uml語言
- 反射
- 類型約束
- 調試
- lamp
- lnmp
- composer
- 工作常用
- UML圖
- 常見問題