一文帶你搞懂PHP單例模式
簡介
單例模式是創建型對象的一種,用於如何優雅的創建對象。
讓一個類最多產生一個對象。
場景
隻需要一個對象就能解決並且要使用多次的場景,比如框架的數據庫連接。
優點
減少資源消耗,一個對象能完成的事情,就不需要再實例化出來同樣的東西。
缺點
對象生命周期都是頁面級的,每次頁面被執行時,都會重新建立新的對象,都會在頁面執行完畢後被清空,這樣似乎PHP單例模式意義不大。
示例代碼
class Demo { //聲明一個存儲對象的方法 private static $obj; //防止當前類的外部進行實例化 private function __construct() {} //防止當前類的外部進行克隆 private function __clone() {} //聲明一獲取示例的方案 public static function getInstance() { if(self::$obj === null) { self::$obj = new self(); } return self::$obj; } public function otherFunction() { //todo ... } }
測試代碼:
class Demo { //聲明一個存儲對象的方法 private static $obj; //防止當前類的外部進行實例化 private function __construct() {} //防止當前類的外部進行克隆 private function __clone() {} //聲明一獲取示例的方案 public static function getInstance() { if(self::$obj === null) { //在此處打印數據到文件,可清楚的看出來執行瞭幾次。 //靜態方法或者靜態屬性可以稱之為類變量或者類屬性,會隨著類的加載一並加載到內存當中。 file_put_contents('F:/stdout.txt', 1,FILE_APPEND); self::$obj = new self(); } return self::$obj; } public function otherFunction() { //todo ... } } //類的外部執行瞭5次實例化操作 for($i = 0; $i < 5; $i++) { Demo::getInstance(); }
升級版本:
如果每一個類都寫一個單例模式的話,會顯得有重復的代碼,為此可以用繼承去解決這個問題。
此時self就需要修改為static,不然self是當前對象而不是子類對象。
static::方法或屬性,這種使用稱為後期靜態綁定。
這和但是static 修飾成員屬性或者成員方法,一個是使用,一個是修飾。
class Singleton { //聲明一個存儲對象的方法 private static $obj; //防止當前類的外部進行實例化 private function __construct() {} //防止當前類的外部進行克隆 private function __clone() {} //聲明一獲取示例的方案 public static function getInstance() { //檢測$obj是否為空並是否不屬於當前類 if(((static::$obj === null) && (! static::$obj instanceof static))) { static::$obj = new static(); } return static::$obj; } } class Test extends Singleton { public function func() { return mt_rand(0, 10); } } //使用: Test::getInstance()->func();
到此這篇關於一文帶你搞懂PHP單例模式的文章就介紹到這瞭,更多相關PHP單例模式內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!