使用單例模式的出發點:
1、php的應用主要在於資料庫應用, 所以乙個應用中會存在大量的資料庫操作, 使用單例模式, 則可以避免大量的new 操作消耗的資源。
2、如果系統中需要有乙個類來全域性控制某些配置資訊, 那麼使用單例模式可以很方便的實現. 這個可以參看zf的frontcontroller部分。
3、在一次頁面請求中, 便於進行除錯, 因為所有的**(例如資料庫操作類db)都集中在乙個類中, 我們可以在類中設定鉤子, 輸出日誌,從而避免到處var_dump, echo。
創造單例注意:
1、乙個雷只能有乙個類物件(只能例項化乙個物件)
2、它必須自己建立這個例項
3、它必須自行向整個系統提供這個例項
4、建構函式和轉殖函式必須宣告為私有的,這是為了防止外部程式 new 類從而失去單例模式的意義
5、 getinstance()方法必須宣告為公有的,必須呼叫此方法以返回唯一例項的乙個引用
6、擁有乙個儲存類的例項的靜態成員變數
7、php的單例模式是相對而言的,因為php的解釋執行機制使得每個php頁面被解釋執行後,所有的相關資源都會被**
8、擁有乙個訪問這個例項的公共的靜態方法(常用getinstance()方法進行例項化單例類,通過instanceof操作符可以檢測到類是否已經被例項化)
另外,需要建立__clone()方法防止物件被複製(轉殖)
**如下:
1 <?php
2 class danli
3 13
14 //建立__clone方法防止物件被複製轉殖
15 public function __clone()
16
19 20 //單例方法,用於訪問例項的公共的靜態方法
21 public static function getinstance()
22
26 return self::$_instance;
27 }
28 29 public function test()
30
33 34 }
35 36 /*用new例項化private標記建構函式的類會報錯
37 $danli = new danli();
38 39 複製(轉殖)物件將導致乙個e_user_error
40 $danli_clone = clone $danli;
41 */
42 43
44 //正確方法,用雙冒號::操作符訪問靜態方法獲取例項
45 $danli = danli::getinstance();
46 $danli->test();
47 ?>
運用單例模式實現乙個資料庫類:
1<?php
2 class dbhelper
3 16 private function __clone()
17
19 public static function get_class_nmdb($host, $username, $password)
20
27 return self::$_instance;
28 }
29 // 連線資料表
30 public function select_db($database)
31
35 // 執行sql語句
36 public function query($query)
37
40 // 將結果集儲存為陣列
41 public function fetch_array($fetch_array)
42
45 // 獲得記錄數目
46 public function num_rows($query)
47
50 // 關閉資料庫連線
51 public function close()
52
55 }
56 $connector = dbhelper::get_class_nmdb($host, $username, $password);
57 $connector -> select_db($database);
58 ?>
1 <?php
2 /*
3 * mysql 單例
4 */
5 class mysql else
24 mysql_select_db($this->database) or $this->err();
25 $this->query("set names ''", $this->link);
26 return $this->link;
27 }
28 /**
29 * 防止被轉殖
30 *
31 */
32 private function __clone(){}
33 public static function getinstance($pconnect = false)
37 return self::$_instance;
38 }
39 /**
40 * 查詢
41 */
42 public function query($sql, $link = '')
46 /**
47 * 單行記錄
48 */
49 public function getrow($sql, $type = mysql_assoc)
53 /**
54 * 多行記錄
55 */
56 public function getrows($sql, $type = mysql_assoc)
61 return $this->rows;
62 }
63 /**
64 * 錯誤資訊輸出
65 */
66 protected function err($sql = null)
71 }
72 //用例
73 $db = mysql::getinstance();
74 $db2 = mysql::getinstance();
75 $data = $db->getrows('select * from blog');
76 //print_r($data);
77 //判斷兩個物件是否相等
78 if($db === $db2)
81 ?>
用單例模式來設計乙個PHP資料庫類
class nmdb private function clone public static function get class nmdb host,username,password return self instance 連線資料表 public function select db da...
用單例模式寫乙個php資料庫管理類
用慣了codeigniter框架,現在突然要自己用原生php開發,還真有點不習慣。因為介面開發過程中需要進行資料庫的操作。於是參考一些資料建立自己的 資料庫管理類 首先建立資料庫連線配置檔案 db.config.php 資料庫配置檔案 開發用資料庫 define db name order mysq...
php單例模式連線資料庫封裝類
單例模式有三大原則 建構函式不能為public 有乙個儲存例項的靜態成員變數 擁有訪問這個例項的公共靜態方法 基於單例模式的php資料庫連線類 class db static public function getinstance return self instance public functi...