單例模式在特定的情況下可以節省資源的消耗,例如同一頁面對數據庫的多次操作,不需要去new多次從而節省了資源。
單例模式的關鍵在於php中的“instanceof”,它用來檢測一個變量是否是某個類的一個實例。
同時,為了防止用戶去new實例,需要將“__construct”函數權限設置為private。
為了防止用戶進行clone,也要重寫“__clone”方法。
<?php
/*
* 單例數據庫連接
*/
class Db {
private static $_instance; //static可以保存值不丟失
private static $_dbConnect;
private $_dbConfig = array(
'host' => '127.0.0.1',
'user' => 'root',
'password' => '',
'database' => 'yii2basic',
);//保存數據庫的配置信息
//使用private防止用戶new
private function __construct(){
}
//重寫clone防止用戶進行clone
public function __clone(){
//當用戶clone操作時產生一個錯誤信息
trigger_error("Can't clone object",E_USER_ERROR);
}
//由類的自身來進行實例化
public static function getInstance(){
if(!(self::$_instance instanceof self)){
self::$_instance = new self();
}
return self::$_instance;
}
public function connect(){
self::$_dbConnect = @mysql_connect($this->_dbConfig['host'],
$this->_dbConfig['user'],$this->_dbConfig['password']);
if(!self::$_dbConnect){
throw new Exception("mysql connect error".mysql_error());
//die("mysql connect error".mysql_error());
}
mysql_query("SET NAMES UTF8");
mysql_select_db($this->_dbConfig['database'],self::$_dbConnect);
return self::$_dbConnect;
}
}
$a = Db::getInstance();
try{
$a->connect();
}catch(Exception $e){
echo "sorry,error was happend.".$e->getMessage();
}