單例模式(職責模式): 簡單的說,一個對象(在學習設計模式之前,需要比較了解面向對象思想)只負責一個特定的任務; 單例類: 1、構造函數需要標記為private(訪問控制:防止外部代碼使用new操作符創建對象),單例類不能在其他類中實例化,只能被其自身實例化; 2、擁有一個保存類的實例的靜態成員變量 3、擁有一個訪問這個實例的公共的靜態方法(常用getInstance()方法進行實例化單例類,通過instanceof操作符可以檢測到類是否已經被實例化) 另外,需要創建__clone()方法防止對象被復制(克隆) 為什麼要使用PHP單例模式? 1、php的應用主要在於數據庫應用, 所以一個應用中會存在大量的數據庫操作, 使用單例模式, 則可以避免大量的new 操作消耗的資源。 2、如果系統中需要有一個類來全局控制某些配置信息, 那麼使用單例模式可以很方便的實現. 這個可以參看ZF的FrontController部分。 3、在一次頁面請求中, 便於進行調試, 因為所有的代碼(例如數據庫操作類db)都集中在一個類中, 我們可以在類中設置鉤子, 輸出日志,從而避免到處var_dump, echo。 代碼實現: <111?111php111 /1** * 設計模式之單例模式 * $_instance必須聲明為靜態的私有變量 * 構造函數和析構函數必須聲明為私有,防止外部程序new * 類從而失去單例模式的意義 * getInstance()方法必須設置為公有的,必須調用此方法 * 以返回實例的一個引用 * ::操作符只能訪問靜態變量和靜態函數 * new對象都會消耗內存 * 使用場景:最常用的地方是數據庫連接。 * 使用單例模式生成一個對象後, * 該對象可以被其它眾多對象所使用。 */ class Danli { //保存類實例的靜態成員變量 private static $_instance; //private標記的構造方法 private function __construct(){ echo 'This is a Constructed method;'; } //創建__clone方法防止對象被復制克隆 public function __clone(){ trigger_error('Clone is not allow!',E_USER_ERROR); } //單例方法,用於訪問實例的公共的靜態方法 public static function getInstance(){ if(!(self::$_instance instanceof self)){ self::$_instance = new self; } return self::$_instance; } public function test(){ echo '調用方法成功'; } } //用new實例化private標記構造函數的類會報錯 //$danli = new Danli(); //正確方法,用雙冒號::操作符訪問靜態方法獲取實例 $danli = Danli::getInstance(); $danli->test(); //復制(克隆)對象將導致一個E_USER_ERROR $danli_clone = clone $danli;