本文實例講述了PHP設計模式之單例模式原理與實現方法。分享給大家供大家參考,具體如下:
一、什么是單例模式
作為對象的創建模式,單例模式確保某一個類只有一個實例,并且對外提供這個全局實例的訪問入口。它不會創建實例副本,而是會向單例類內部存儲的實例返回一個引用。
二、PHP單例模式三要素
1. 需要一個保存類的唯一實例的靜態成員變量。
2. 構造函數和克隆函數必須聲明為私有的,防止外部程序創建或復制實例副本。
3. 必須提供一個訪問這個實例的公共靜態方法,從而返回唯一實例的一個引用。
三、為什么使用單例模式
使用單例模式的好處很大,以數據庫操作為例。若不采用單例模式,當程序中出現大量數據庫操作時,每次都要執行new操作,每次都會消耗大量的內存資源和系統資源,而且每次打開和關閉數據庫連接都是對數據庫的一種極大考驗和浪費。使用了單例模式,只需要實例化一次,不需要每次都執行new操作,極大降低了資源的耗費。
四、單例模式示例
這里以數據庫操作為例
?php
/**
* 單例模式
**/
class Db
{
//保存全局實例
private static $instance;
//數據庫連接句柄
private $db;
//數據庫連接參數
const HOSTNAME = "127.0.0.1";
const USERNAME = "root";
const PASSWORD = "root";
const DBNAME = "testdb";
//私有化構造函數,防止外界實例化對象
private function __construct()
{
$this->db = mysqli_connect(self::HOSTNAME,self::USERNAME,
self::PASSWORD,self::DBNAME);
}
//私有化克隆函數,防止外界克隆對象
private function __clone()
{
}
//單例訪問統一入口
public static function getInstance()
{
if(!(self::$instance instanceof self))
{
self::$instance = new self();
}
return self::$instance;
}
//數據庫查詢操作
public function getinfo()
{
$sql = "select * from testtb";
$res = mysqli_query($this->db,$sql);
while($row = mysqli_fetch_array($res)) {
echo $row['testcol'] . 'br />';
}
mysqli_free_result($res);
}
}
$mysqli = Db::getInstance();
$mysqli->getinfo();
?>
更多關于PHP相關內容感興趣的讀者可查看本站專題:《php面向對象程序設計入門教程》、《PHP數組(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運算與運算符用法總結》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
您可能感興趣的文章:- php單態設計模式(單例模式)實例
- php設計模式 Singleton(單例模式)
- php設計模式之單例模式使用示例
- PHP設計模式之工廠模式與單例模式
- PHP中常用的三種設計模式詳解【單例模式、工廠模式、觀察者模式】
- PHP設計模式之觀察者模式入門與應用案例詳解
- PHP設計模式之中介者模式(Mediator Pattern)入門與應用案例詳解
- PHP設計模式之迭代器(Iterator)模式入門與應用詳解
- PHP設計模式之解釋器(Interpreter)模式入門與應用詳解
- PHP經典面試題之設計模式(經常遇到)
- php設計模式小結
- PHP設計模式之單例模式入門與應用詳解