站長資訊網
        最全最豐富的資訊網站

        一招解決 PHP 單例模式解析和實戰

        我們學習了解了這么多關于PHP的知識,今天學習如何一招解決 PHP 單例模式解析和實戰,不知你們是否已經完全掌握了呢,如果沒有,那就跟隨本篇文章一起繼續學習吧

        一、什么是單例模式?

        1、含義

        作為對象的創建模式,單例模式確保某一個類只有一個實例,而且自行實例化并向整個系統全局地提供這個實例。它不會創建實例副本,而是會向單例類內部存儲的實例返回一個引用。

        2、單例模式的三個要點:

        (1). 需要一個保存類的唯一實例的靜態成員變量:

        private static $_instance;

        (2). 構造函數和克隆函數必須聲明為私有的,防止外部程序new類從而失去單例模式的意義:

        private function __construct()  {      $this->_db = pg_connect('xxxx'); }  private function __clone() { }//覆蓋__clone()方法,禁止克隆

        (3). 必須提供一個訪問這個實例的公共的靜態方法(通常為getInstance方法),從而返回唯一實例的一個引用

            public static function getInstance()       {           if(! (self::$_instance instanceof self) )          {               self::$_instance = new self();           }         return self::$_instance;        }

        二、為什么要使用單例模式?

        1、PHP缺點:

        PHP語言是一種解釋型的腳本語言,這種運行機制使得每個PHP頁面被解釋執行后,所有的相關資源都會被回收。也就是說,PHP在語言級別上沒有辦法讓某個對象常駐內存,這和asp.net、Java等編譯型是不同的,比如在Java中單例會一直存在于整個應用程序的生命周期里,變量是跨頁面級的,真正可以做到這個實例在應用程序生命周期中的唯一性。然而在PHP中,所有的變量無論是全局變量還是類的靜態成員,都是頁面級的,每次頁面被執行時,都會重新建立新的對象,都會在頁面執行完畢后被清空,這樣似乎PHP單例模式就沒有什么意義了,所以PHP單例模式我覺得只是針對單次頁面級請求時出現多個應用場景并需要共享同一對象資源時是非常有意義的。

        2、單例模式在PHP中的應用場合:

        (1)、應用程序與數據庫交互

        一個應用中會存在大量的數據庫操作,比如過數據庫句柄來連接數據庫這一行為,使用單例模式可以避免大量的new操作,因為每一次new操作都會消耗內存資源和系統資源。

        (2)、控制配置信息

        如果系統中需要有一個類來全局控制某些配置信息, 那么使用單例模式可以很方便的實現.

        三、如何實現單例模式?

        1、普通的數據庫訪問例子:

        <?php ...... //初始化一個數據庫句柄 $db = new DB(...);  //添加用戶信息 $db->addUserInfo(...);  ......  //在函數中訪問數據庫,查找用戶信息 function getUserInfo() {     $db = new DB(...);//再次new 數據庫類,和數據庫建立連接     $db = query(....);//根據查詢語句訪問數據庫 }  ?>

        2、應用單例模式對數據庫進行操作:

        <?php  class DB   {       private $_db;       private static $_instance;          private function __construct(...)       {           $this->_db = pg_connect(...);//postgrsql       }          private function __clone() {};  //覆蓋__clone()方法,禁止克隆          public static function getInstance()       {           if(! (self::$_instance instanceof self) ) {               self::$_instance = new self();           }           return self::$_instance;       }                public function addUserInfo(...)     {           }       public function getUserInfo(...)     {       }  }  //test  $db = DB::getInstance();  $db->addUserInfo(...);  $db->getUserInfo(...);   ?>

        3、深入理解

        <?php class db { 	public $conn; 	public static $sql; 	public static $instance=null; 	private function __construct(){ 		require_once('db.config.php'); 		$this->conn = mysql_connect($db['host'],$db['user'],$db['password']); 		if(!mysql_select_db($db['database'],$this->conn)){ 			echo "失敗"; 		}; 		mysql_query('set names utf8',$this->conn);		 	} 	public static function getInstance(){ 		if(is_null(self::$instance)){ 			self::$instance = new db; 		} 		return self::$instance; 	} 	/** 	 * 查詢數據庫 	 */ 	public function select($table,$condition=array(),$field = array()){ 		$where=''; 		if(!empty($condition)){ 			 			foreach($condition as $k=>$v){ 				$where.=$k."='".$v."' and "; 			} 			$where='where '.$where .'1=1'; 		} 		$fieldstr = ''; 		if(!empty($field)){ 			 			foreach($field as $k=>$v){ 				$fieldstr.= $v.','; 			} 			 $fieldstr = rtrim($fieldstr,','); 		}else{ 			$fieldstr = '*'; 		} 		self::$sql = "select {$fieldstr} from {$table} {$where}"; 		$result=mysql_query(self::$sql,$this->conn); 		$resuleRow = array(); 		$i = 0; 		while($row=mysql_fetch_assoc($result)){ 			foreach($row as $k=>$v){ 				$resuleRow[$i][$k] = $v; 			} 			$i++; 		} 		return $resuleRow; 	} 	/** 	 * 添加一條記錄 	 */ 	 public function insert($table,$data){ 	 	$values = ''; 	 	$datas = ''; 	 	foreach($data as $k=>$v){ 	 		$values.=$k.','; 	 		$datas.="'$v'".','; 	 	} 	 	$values = rtrim($values,','); 	 	$datas   = rtrim($datas,','); 	 	self::$sql = "INSERT INTO  {$table} ({$values}) VALUES ({$datas})"; 		if(mysql_query(self::$sql)){ 			return mysql_insert_id(); 		}else{ 			return false; 		}; 	 } 	 /** 	  * 修改一條記錄 	  */ 	public function update($table,$data,$condition=array()){ 		$where=''; 		if(!empty($condition)){ 			 			foreach($condition as $k=>$v){ 				$where.=$k."='".$v."' and "; 			} 			$where='where '.$where .'1=1'; 		} 		$updatastr = ''; 		if(!empty($data)){ 			foreach($data as $k=>$v){ 				$updatastr.= $k."='".$v."',"; 			} 			$updatastr = 'set '.rtrim($updatastr,','); 		} 		self::$sql = "update {$table} {$updatastr} {$where}"; 		return mysql_query(self::$sql); 	} 	/** 	 * 刪除記錄 	 */ 	 public function delete($table,$condition){ 	 	$where=''; 		if(!empty($condition)){ 			 			foreach($condition as $k=>$v){ 				$where.=$k."='".$v."' and "; 			} 			$where='where '.$where .'1=1'; 		} 		self::$sql = "delete from {$table} {$where}"; 		return mysql_query(self::$sql); 		 	 } 	 	public static function getLastSql(){ 		echo self::$sql; 	} 	 	 	 }  $db = db::getInstance(); //$list = $db->select('demo',array('name'=>'tom','password'=>'ds'),array('name','password')); //echo $db->insert('demo',array('name'=>'最近你啦','password'=>'123')); //echo $db->update('demo',array("name"=>'xxx',"password"=>'123'),array('id'=>1)); echo $db->delete('demo',array('id'=>'2')); db::getLastSql(); echo "<pre>"; ?>

        推薦學習:《PHP視頻教程》

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产综合免费精品久久久| 亚洲国产精品无码久久一区二区| 日韩精品中文字幕第2页| 国产第一福利精品导航| 亚洲人精品午夜射精日韩| 国产成人精品一区在线 | 无码人妻一区二区三区精品视频| 欧美精品黑人巨大在线播放| 久久精品国产亚洲av影院| 亚洲欧美日韩国产精品专区| 久久精品视频91| 国精品无码A区一区二区| 91亚洲精品自在在线观看| 国产成人精品亚洲日本在线| 国产精品v片在线观看不卡| 久久精品国产亚洲AV无码娇色| 亚洲AV无码久久精品狠狠爱浪潮| 欧美国产精品va在线观看| 国产精品亚洲一区二区在线观看| 99久久国产综合精品五月天喷水| 青青草国产精品久久| 99视频在线观看精品| 99热成人精品热久久669| av国内精品久久久久影院| 99久久久国产精品免费无卡顿 | 刺激无码在线观看精品视频| 国产成人精品免费午夜app| 538国产精品一区二区在线| 2020亚洲男人天堂精品| 国产精品日本一区二区在线播放| 精品视频无码一区二区三区| 久久精品黄AA片一区二区三区| 久久久国产乱子伦精品作者| 久久久精品人妻一区二区三区四| 无码精品国产VA在线观看DVD| 无码精品人妻一区二区三区人妻斩| 亚洲精品国产品国语在线| 亚洲AV无码精品色午夜在线观看| 亚洲∧v久久久无码精品| 欧美精品中文字幕亚洲专区| 精品无码久久久久国产|