首頁 後端開發 php教程 一招解決 PHP 單例模式解析與實戰

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

Jun 30, 2021 am 09:49 AM
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(&#39;db.config.php&#39;);
		$this->conn = mysql_connect($db[&#39;host&#39;],$db[&#39;user&#39;],$db[&#39;password&#39;]);
		if(!mysql_select_db($db[&#39;database&#39;],$this->conn)){
			echo "失败";
		};
		mysql_query(&#39;set names utf8&#39;,$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=&#39;&#39;;
		if(!empty($condition)){
			
			foreach($condition as $k=>$v){
				$where.=$k."=&#39;".$v."&#39; and ";
			}
			$where=&#39;where &#39;.$where .&#39;1=1&#39;;
		}
		$fieldstr = &#39;&#39;;
		if(!empty($field)){
			
			foreach($field as $k=>$v){
				$fieldstr.= $v.&#39;,&#39;;
			}
			 $fieldstr = rtrim($fieldstr,&#39;,&#39;);
		}else{
			$fieldstr = &#39;*&#39;;
		}
		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 = &#39;&#39;;
	 	$datas = &#39;&#39;;
	 	foreach($data as $k=>$v){
	 		$values.=$k.&#39;,&#39;;
	 		$datas.="&#39;$v&#39;".&#39;,&#39;;
	 	}
	 	$values = rtrim($values,&#39;,&#39;);
	 	$datas   = rtrim($datas,&#39;,&#39;);
	 	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=&#39;&#39;;
		if(!empty($condition)){
			
			foreach($condition as $k=>$v){
				$where.=$k."=&#39;".$v."&#39; and ";
			}
			$where=&#39;where &#39;.$where .&#39;1=1&#39;;
		}
		$updatastr = &#39;&#39;;
		if(!empty($data)){
			foreach($data as $k=>$v){
				$updatastr.= $k."=&#39;".$v."&#39;,";
			}
			$updatastr = &#39;set &#39;.rtrim($updatastr,&#39;,&#39;);
		}
		self::$sql = "update {$table} {$updatastr} {$where}";
		return mysql_query(self::$sql);
	}
	/**
	 * 删除记录
	 */
	 public function delete($table,$condition){
	 	$where=&#39;&#39;;
		if(!empty($condition)){
			
			foreach($condition as $k=>$v){
				$where.=$k."=&#39;".$v."&#39; and ";
			}
			$where=&#39;where &#39;.$where .&#39;1=1&#39;;
		}
		self::$sql = "delete from {$table} {$where}";
		return mysql_query(self::$sql);
		
	 }
	
	public static function getLastSql(){
		echo self::$sql;
	}
	
	
	
}

$db = db::getInstance();
//$list = $db->select(&#39;demo&#39;,array(&#39;name&#39;=>&#39;tom&#39;,&#39;password&#39;=>&#39;ds&#39;),array(&#39;name&#39;,&#39;password&#39;));
//echo $db->insert(&#39;demo&#39;,array(&#39;name&#39;=>&#39;最近你啦&#39;,&#39;password&#39;=>&#39;123&#39;));
//echo $db->update(&#39;demo&#39;,array("name"=>&#39;xxx&#39;,"password"=>&#39;123&#39;),array(&#39;id&#39;=>1));
echo $db->delete(&#39;demo&#39;,array(&#39;id&#39;=>&#39;2&#39;));
db::getLastSql();
echo "<pre class="brush:php;toolbar:false">";
?>

推荐学习:《PHP视频教程

以上是一招解決 PHP 單例模式解析與實戰的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Stock Market GPT

Stock Market GPT

人工智慧支援投資研究,做出更明智的決策

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

如何在PHP中實現單身模式? 如何在PHP中實現單身模式? Sep 25, 2025 am 12:27 AM

單例模式確保一個類只有一個實例,並提供全局訪問點,適用於需要單一對象協調系統操作的場景,如數據庫連接或配置管理。 2.其基本結構包括:私有的靜態屬性存儲實例、私有構造函數防止外部創建、私有克隆方法防止複制,以及公共靜態方法(如getInstance())用於獲取實例。 3.在PHP中通過調用getInstance()方法獲取唯一實例,無論調用多少次都返回同一對象引用。 4.標準PHP請求模型下無需考慮線程安全,但在長運行或多線程環境中需注意同步問題,而PHP本身不支持原生鎖機制。 5.儘管單例有用,但會

如何在php中使用無效的合併操作員(??)? 如何在php中使用無效的合併操作員(??)? Sep 25, 2025 am 01:28 AM

答案:PHP的空合併操作符(??)用於檢查變量或數組鍵是否存在且非null,若成立則返回其值,否則返回默認值。它可避免使用冗長的isset()檢查,適用於處理未定義變量和數組鍵,如$username=$userInput??'guest',且支持鍊式調用,如$theme=$userTheme??$defaultTheme??'dark',特別適合表單、配置和用戶輸入處理,但僅排除null值,空字符串、0或false均被視為有效值返回。

如何在PHP中獲取URL參數? 如何在PHP中獲取URL參數? Sep 24, 2025 am 05:11 AM

使用$_GET獲取URL參數,如?name=John&age=25;通過isset或空合併運算符檢查存在性,並用filter_input過濾和驗證數據以確保安全。

manwa2網頁版直達鏈接_manwa2(澳版)網頁入口最新更新 manwa2網頁版直達鏈接_manwa2(澳版)網頁入口最新更新 Sep 23, 2025 am 11:42 AM

manwa2網頁版直達鏈接是http://www.manwaw.cn/,該平台提供海量高清漫畫資源,支持在線搜索、離線緩存與多端同步,具備個性化書單和閱讀設置功能,確保用戶流暢舒適的追漫體驗。

如何在PHP中禁用功能? 如何在PHP中禁用功能? Sep 24, 2025 am 02:40 AM

TodisableaPHPfunction,usedisable_functionsinphp.iniforbuilt-infunctionslikeexecorsystem,whichblocksthemgloballyforsecurity;foruser-definedfunctions,preventexecutionbywrappingtheminconditions,renaming,commentingout,orcontrollingfileinclusionviaautoloa

如何從PHP中的URL下載文件? 如何從PHP中的URL下載文件? Sep 24, 2025 am 05:45 AM

答案:使用file_get_contents和cURL可下載URL文件,前者簡單但受限制,後者更靈活且支持流式處理。示例包括直接讀取寫入文件、cURL初始化設置選項並保存、添加錯誤處理及HTTP狀態檢查,大文件推薦分塊流式下載以節省內存,確保目錄可寫並妥善處理異常。

如何在PHP類中實現接口? 如何在PHP類中實現接口? Sep 25, 2025 am 05:34 AM

使用implements關鍵字實現接口,類必須提供接口中所有方法的具體實現。 2.定義接口用interface關鍵字聲明方法。 3.類實現接口並重寫方法。 4.創建對象調用方法輸出結果。 5.一個類可實現多個接口,確保代碼規範和可維護性。

如何對用戶輸入進行消毒以防止PHP中的XSS? 如何對用戶輸入進行消毒以防止PHP中的XSS? Sep 25, 2025 am 05:19 AM

TopreventXSSinPHP,sanitizeuserinputandescapeoutputbasedoncontextusinghtmlspecialchars()forHTML,json_encode()forJavaScript,andvalidatestrictlywithfilter_var()forexpecteddatatypes,whileavoidingdeprecatedfunctionsandusingContent-Security-Policyheadersfo

See all articles