你如何能輕松方便地建立這么" 復雜 " 的對象即操作中不需要粘貼復制呢?

解決方法

建立一個工廠(一個函數或一個類方法)來制造新的對象。為了理解工廠的用處, 試想以下的不同之處……

代碼:

復制代碼 代碼 " /> 亚洲精品日韩综合观看成人91,亚洲精品一区中文字幕乱码,九九精品免费

中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

介紹php設計模式中的工廠模式

問題

你如何能輕松方便地建立這么" 復雜 " 的對象即操作中不需要粘貼復制呢?

解決方法

建立一個工廠(一個函數或一個類方法)來制造新的對象。為了理解工廠的用處, 試想以下的不同之處……

代碼:

復制代碼 代碼如下:
$connection =& new MySqlConnection($user, $password, $database); 

……使你的代碼可擴展和更簡潔……

復制代碼 代碼如下:
$connection =& create_connection(); 

后者的代碼片斷集中在和數據庫連接的create_connect()工廠上 ,就像剛才說的一樣,使創造數據庫連接的過程成為一個簡單的操作―就像new操作一樣。工廠模式的優點就在創建對象上。 它的任務就是把對象的創建過程都封裝起來,然后返回一個所需要的新類。

想改變對象的結構和建立對象的方式嗎? 你只需選擇對象工廠,對代碼的改變只需要一次就夠了。( 工廠模式的功能是如此強大, 它處于是應用的底層, 所以在許多其余的復雜模式和應用中它會不停地出現。)

樣本代碼

工廠模式封裝了對象的建立過程。 你可以在對象本身創建對象工廠或者是一個額外的工廠類――這要看你具體的應用。讓我們看一個工廠對象的例子。

我們發現下面代碼中,數據庫連接的那部分屢次出現:

復制代碼 代碼如下:
// php
class Product { 
function getList() { $db =& new MysqlConnection(DB_USER, DB_PW, DB_NAME); 
//... 

function getByName($name) { $db =& new MysqlConnection(DB_USER, DB_PW, DB_NAME); 
//... 

//... 

為什么這樣做不好? 數據庫連接的參數出現的地方太多了,當你把這些參數設成常量,意味著你統一定義并對他們進行賦值,顯然這種做法不是很妥當:

你可以輕松地改變連接數據庫的參數,但你不能增加或改變這些參數地順序,除非你把所有連接代碼都改了。
你不能輕松的實例化一個新類去連接另一種數據庫,比如說PostgresqlConnection。
這樣很難單獨測試和證實連接對象的狀態。
使用工廠設計模式,代碼將得到很大的改進:

復制代碼 代碼如下:
class Product { 
function getList() { 
$db =& $this->_getConnection(); 
//... 

function &_getConnection() { 
return new MysqlConnection(DB_USER, DB_PW, DB_NAME); 


先前的類中存在很多調用new MysqlConnection(DB_USER,  DB_PW,  DB_NAME)的方法,現在都被集中到的_getConnection()方法上。

php技術介紹php設計模式中的工廠模式,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 在线免费亚洲视频 | 成人国产精品久久久 | 久久久久久久久久毛片 | 亚洲精品久久久久久国产精华液 | 国产亚洲精品久久19p | 久久精品影视 | 成人精品一区亚洲午夜久久久 | 五月婷亚洲| 欧美日韩一区二区在线观看 | 久久久999国产精品 中文字幕在线精品 | 久久国产精品免费一区二区三区 | 伊人免费在线 | www国产成人免费观看视频 | 久久成人一区 | 日韩视频在线播放 | 亚洲永久精品国产 | 一区二区伦理电影 | 欧美日韩在线综合 | 一级黄a视频 | 欧美性视频在线播放 | 一级久久久久久 | 99久久精品免费看国产小宝寻花 | 日韩久久久久久 | 国产精品欧美精品 | 国产日韩精品在线 | 国产精品99久久免费观看 | 欧美成人a∨高清免费观看 色999日韩 | 精品在线免费看 | 久久久久国产精品午夜一区 | 亚洲日本欧美日韩高观看 | 久久久国产一区二区三区四区小说 | 黄色一级毛片免费看 | 国产日韩欧美激情 | 国产乱码一二三区精品 | 岛国av免费在线观看 | 在线免费观看黄视频 | 精品视频在线观看 | 日本成人中文字幕 | 天天插日日操 | 日本精品视频在线 | 亚洲成网站 |