php設計模式之單例模式實例分析_PHP教程
推薦:PHP中字符安全過濾函數使用小結這篇文章主要簡單介紹了PHP中字符安全過濾函數,對于防止sql注入攻擊XSS攻擊能非常有用,這里推薦給大家。 在WEB開發過程中,我們經常要獲取來自于世界各地的用戶輸入的數據。但是,我們永遠都不能相信那些用戶輸入的數據。所以在各種的Web開發語言中,都會提供保證用
這篇文章主要介紹了php設計模式之單例模式,實例分析了單例模式的原理與相關使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下
本文實例講述了php設計模式之單例模式。分享給大家供大家參考。具體分析如下:
單例模式(職責模式):
簡單的說,一個對象(在學習設計模式之前,需要比較了解面向對象思想)只負責一個特定的任務;
單例類:
1、構造函數需要標記為private(訪問控制:防止外部代碼使用new操作符創建對象),單例類不能在其他類中實例化,只能被其自身實例化;
2、擁有一個保存類的實例的靜態成員變量
3、擁有一個訪問這個實例的公共的靜態方法(常用getInstance()方法進行實例化單例類,通過instanceof操作符可以檢測到類是否已經被實例化)
另外,需要創建__clone()方法防止對象被復制(克隆)
為什么要使用PHP單例模式?
1、php的應用主要在于數據庫應用, 所以一個應用中會存在大量的數據庫操作, 使用單例模式, 則可以避免大量的new 操作消耗的資源。
2、如果系統中需要有一個類來全局控制某些配置信息, 那么使用單例模式可以很方便的實現. 這個可以參看ZF的FrontController部分。
3、在一次頁面請求中, 便于進行調試, 因為所有的代碼(例如數據庫操作類db)都集中在一個類中, 我們可以在類中設置鉤子, 輸出日志,從而避免到處var_dump, echo。
代碼實現:
?希望本文所述對大家的php程序設計有所幫助。
分享:PHP 魔術變量和魔術函數詳解這篇文章主要簡單介紹了PHP 魔術變量和魔術函數,以及使用示例,方便我們學習理解php魔術變量和魔術函數,有需要的小伙伴參考下吧。 魔術變量 PHP 向它運行的任何腳本提供了大量的預定義常量。 不過很多常量都是由不同的擴展庫定義的,只有在加載了這些擴展庫時才會出
- 相關鏈接:
- 教程說明:
PHP教程-php設計模式之單例模式實例分析
。