欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

介紹php設(shè)計(jì)模式中的工廠模式

 更新時(shí)間:2008年06月12日 20:14:02   作者:  
在面向?qū)ο缶幊讨? 最通常的方法是一個(gè)new操作符產(chǎn)生一個(gè)對(duì)象實(shí)例,new操作符就是用來(lái)構(gòu)造對(duì)象實(shí)例的。但是在一些情況下, new操作符直接生成對(duì)象會(huì)帶來(lái)一些問(wèn)題。舉例來(lái)說(shuō), 許多類(lèi)型對(duì)象的創(chuàng)造需要一系列的步驟: 你可能需要計(jì)算或取得對(duì)象的初始設(shè)置; 選擇生成哪個(gè)子對(duì)象實(shí)例; 或在生成你需要的對(duì)象之前必須先生成一些輔助功能的對(duì)象。 在這些情況, 新對(duì)象的建立就是一個(gè) “過(guò)程”,不僅是一個(gè)操作,像一部大機(jī)器中的一個(gè)齒輪傳動(dòng)。
問(wèn)題

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

解決方法

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

代碼:

復(fù)制代碼 代碼如下:

$connection =& new MySqlConnection($user, $password, $database); 

……使你的代碼可擴(kuò)展和更簡(jiǎn)潔……

復(fù)制代碼 代碼如下:

$connection =& create_connection(); 

后者的代碼片斷集中在和數(shù)據(jù)庫(kù)連接的create_connect()工廠上 ,就像剛才說(shuō)的一樣,使創(chuàng)造數(shù)據(jù)庫(kù)連接的過(guò)程成為一個(gè)簡(jiǎn)單的操作—就像new操作一樣。工廠模式的優(yōu)點(diǎn)就在創(chuàng)建對(duì)象上。 它的任務(wù)就是把對(duì)象的創(chuàng)建過(guò)程都封裝起來(lái),然后返回一個(gè)所需要的新類(lèi)。

想改變對(duì)象的結(jié)構(gòu)和建立對(duì)象的方式嗎? 你只需選擇對(duì)象工廠,對(duì)代碼的改變只需要一次就夠了。( 工廠模式的功能是如此強(qiáng)大, 它處于是應(yīng)用的底層, 所以在許多其余的復(fù)雜模式和應(yīng)用中它會(huì)不停地出現(xiàn)。)

樣本代碼

工廠模式封裝了對(duì)象的建立過(guò)程。 你可以在對(duì)象本身創(chuàng)建對(duì)象工廠或者是一個(gè)額外的工廠類(lèi)——這要看你具體的應(yīng)用。讓我們看一個(gè)工廠對(duì)象的例子。

我們發(fā)現(xiàn)下面代碼中,數(shù)據(jù)庫(kù)連接的那部分屢次出現(xiàn):

復(fù)制代碼 代碼如下:

// PHP4 
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); 
//... 

//... 

為什么這樣做不好? 數(shù)據(jù)庫(kù)連接的參數(shù)出現(xiàn)的地方太多了,當(dāng)你把這些參數(shù)設(shè)成常量,意味著你統(tǒng)一定義并對(duì)他們進(jìn)行賦值,顯然這種做法不是很妥當(dāng):

你可以輕松地改變連接數(shù)據(jù)庫(kù)的參數(shù),但你不能增加或改變這些參數(shù)地順序,除非你把所有連接代碼都改了。
你不能輕松的實(shí)例化一個(gè)新類(lèi)去連接另一種數(shù)據(jù)庫(kù),比如說(shuō)PostgresqlConnection。
這樣很難單獨(dú)測(cè)試和證實(shí)連接對(duì)象的狀態(tài)。
使用工廠設(shè)計(jì)模式,代碼將得到很大的改進(jìn):

復(fù)制代碼 代碼如下:

class Product { 
function getList() { 
$db =& $this->_getConnection(); 
//... 

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


先前的類(lèi)中存在很多調(diào)用new MysqlConnection(DB_USER,  DB_PW,  DB_NAME)的方法,現(xiàn)在都被集中到的_getConnection()方法上。

相關(guān)文章

最新評(píng)論