PHP最常用的2種設(shè)計(jì)模式工廠模式和單例模式介紹
更新時(shí)間:2012年08月14日 08:58:42 作者:
當(dāng)你在不斷的試圖從你的應(yīng)用程序中發(fā)現(xiàn)新的特征時(shí),你是否發(fā)現(xiàn)你提出的解決方法和一些以前你已經(jīng)實(shí)現(xiàn)的東西是如此的類(lèi)似呢
1.工廠模式
主要作用是降低耦合度。
abstract class Operation{
abstract public function getValue($num1,$num2);
public function getAttr(){
return 1;
}
}
class Add extends Operation{
public function getValue($num1, $num2){
return $num1+$num2;
}
}
class Sub extends Operation{
public function getValue($num1, $num2){
return $num1-$num2;
}
}
class Factory{
public static function CreateObj($operation){
switch ($operation){
case '+': return new Add();
case '-': return new Sub();
}
}
}
$Op=Factory::CreateObj('-');
echo $Op->getValue(3, 6);
用在真正開(kāi)發(fā)中一般當(dāng)做數(shù)據(jù)庫(kù)選擇類(lèi)。
2單例模式
單例是因?yàn)橐粋€(gè)就足夠了,多了浪費(fèi)。比如郵局里的電話(huà)簿只有一本,有需要的人拿來(lái)看,沒(méi)有必要每個(gè)人要查的時(shí)候工作人員就拿一本出來(lái),看完了再回收。
class Mysql{
public static $conn;
public static function getInstance(){
if (!self::$conn){
new self();
return self::$conn;
}else {
return self::$conn;
}
}
private function __construct(){
self::$conn= "mysql_connect:";// mysql_connect('','','')
}
public function __clone()
{
trigger_error("Only one connection");
}
}
echo Mysql::getInstance();
echo Mysql::getInstance();
實(shí)際中用作數(shù)據(jù)庫(kù)連接類(lèi)和工廠模式一起使用,根據(jù)參數(shù)調(diào)用單例模式,可以提高資源使用效率。
主要作用是降低耦合度。
復(fù)制代碼 代碼如下:
abstract class Operation{
abstract public function getValue($num1,$num2);
public function getAttr(){
return 1;
}
}
class Add extends Operation{
public function getValue($num1, $num2){
return $num1+$num2;
}
}
class Sub extends Operation{
public function getValue($num1, $num2){
return $num1-$num2;
}
}
class Factory{
public static function CreateObj($operation){
switch ($operation){
case '+': return new Add();
case '-': return new Sub();
}
}
}
$Op=Factory::CreateObj('-');
echo $Op->getValue(3, 6);
用在真正開(kāi)發(fā)中一般當(dāng)做數(shù)據(jù)庫(kù)選擇類(lèi)。
2單例模式
單例是因?yàn)橐粋€(gè)就足夠了,多了浪費(fèi)。比如郵局里的電話(huà)簿只有一本,有需要的人拿來(lái)看,沒(méi)有必要每個(gè)人要查的時(shí)候工作人員就拿一本出來(lái),看完了再回收。
復(fù)制代碼 代碼如下:
class Mysql{
public static $conn;
public static function getInstance(){
if (!self::$conn){
new self();
return self::$conn;
}else {
return self::$conn;
}
}
private function __construct(){
self::$conn= "mysql_connect:";// mysql_connect('','','')
}
public function __clone()
{
trigger_error("Only one connection");
}
}
echo Mysql::getInstance();
echo Mysql::getInstance();
實(shí)際中用作數(shù)據(jù)庫(kù)連接類(lèi)和工廠模式一起使用,根據(jù)參數(shù)調(diào)用單例模式,可以提高資源使用效率。
您可能感興趣的文章:
- php設(shè)計(jì)模式 Template (模板模式)
- PHP常用的三種設(shè)計(jì)模式匯總
- php設(shè)計(jì)模式 DAO(數(shù)據(jù)訪問(wèn)對(duì)象模式)
- php設(shè)計(jì)模式 Interpreter(解釋器模式)
- PHP經(jīng)典面試題之設(shè)計(jì)模式(經(jīng)常遇到)
- php設(shè)計(jì)模式小結(jié)
- php設(shè)計(jì)模式之單例模式使用示例
- php 設(shè)計(jì)模式之 工廠模式
- php基礎(chǔ)設(shè)計(jì)模式大全(注冊(cè)樹(shù)模式、工廠模式、單列模式)
- PHP設(shè)計(jì)模式概論【概念、分類(lèi)、原則等】
相關(guān)文章
phpStudy中升級(jí)MySQL版本到5.7.17的方法步驟
這篇文章主要給大家介紹了關(guān)于phpStudy中升級(jí)MySQL版本到5.7.17的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-08-08PHP中用hash實(shí)現(xiàn)的數(shù)組
今天回顧學(xué)習(xí)了PHP中變量實(shí)現(xiàn)的方法,在瀏覽其源碼是發(fā)現(xiàn)在PHP中所有的數(shù)據(jù)類(lèi)型通過(guò)一個(gè)union存儲(chǔ)。php語(yǔ)言是弱類(lèi)型語(yǔ)言,其實(shí)現(xiàn)中通過(guò)記錄變量的類(lèi)型和值來(lái)實(shí)現(xiàn)其管理。2011-07-07php ZipArchive實(shí)現(xiàn)多文件打包下載實(shí)例
在本篇文章里我們給各位整理了關(guān)于php ZipArchive實(shí)現(xiàn)多文件打包下載實(shí)例以及相關(guān)代碼,需要的朋友們可以學(xué)習(xí)下。2019-10-10PHP實(shí)現(xiàn)sha-256哈希算法實(shí)例代碼
最近在PHP項(xiàng)目中使用到了hmac_sha256加密方式,下面這篇文章主要給大家介紹了關(guān)于PHP實(shí)現(xiàn)sha-256哈希算法的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01php+Memcached實(shí)現(xiàn)簡(jiǎn)單留言板功能示例
這篇文章主要介紹了php+Memcached實(shí)現(xiàn)簡(jiǎn)單留言板功能,結(jié)合實(shí)例形式較為詳細(xì)的分析了php結(jié)合memcached實(shí)現(xiàn)留言板的具體步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-02-02