程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 介紹php設計模式中的工廠模式

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

編輯:關於PHP編程

問題

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

解決方法

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

代碼:

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

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

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

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

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

樣本代碼

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

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

復制代碼 代碼如下:
// 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); 
//... 

//... 

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

你可以輕松地改變連接數據庫的參數,但你不能增加或改變這些參數地順序,除非你把所有連接代碼都改了。
你不能輕松的實例化一個新類去連接另一種數據庫,比如說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()方法上。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved