程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> php 單例模式詳細介紹及實現源碼

php 單例模式詳細介紹及實現源碼

編輯:PHP綜合

這篇文章主要介紹了PHP中數據庫單例模式的實現代碼分享,本文先是講解了單例模式的一些知識,然後給出了數據庫單例模式實現代碼。

什麼是單例模式

單例模式顧名思義,就是只有一個實例。

作為對象的創建模式, 單例模式確保某一個類只有一個實例,而且自行實例化並向整個系統提供這個實例,這個類我們稱之為單例類。

單例模式的要點有三個:

一是某個類只能有一個實例;
二是它必須自行創建這個實例;
三是它必須自行向整個系統提供這個實例。 

為什麼要使用PHP單例模式?

1、php的應用主要在於數據庫應用、所以一個應用中會存在大量的數據庫操作、使用單例模式、則可以避免大量的new 操作消耗的資源

2、如果系統中需要有一個類來全局控制某些配置信息、那麼使用單例模式可以很方便的實現. 這個可以參看ZF的FrontController部分

3、在一次頁面請求中、便於進行調試、因為所有的代碼(例如數據庫操作類db)都集中在一個類中、我們可以在類中設置鉤子、輸出日志、從而避免到處var_dump、echo

單例類

1、構造函數需要標記為private(訪問控制:防止外部代碼使用new操作符創建對象)、單例類不能在其他類中實例化、只能被其自身實例化

2、擁有一個保存類的實例的靜態成員變量

3、擁有一個訪問這個實例的公共的靜態方法(常用getInstance()方法進行實例化單例類、通過instanceof操作符可以檢測到類是否已經被實例化)

4、另外、需要創建__clone()方法防止對象被復制(克隆)

php單例模式實現方法

單例模式在特定的情況下可以節省資源的消耗,例如同一頁面對數據庫的多次操作,不需要去new多次從而節省了資源。

單例模式的關鍵在於PHP中的“instanceof”,它用來檢測一個變量是否是某個類的一個實例。

同時,為了防止用戶去new實例,需要將“__construct”函數權限設置為private。

為了防止用戶進行clone,也要重寫“__clone”方法。

<?php
/*
 * 單例數據庫連接
 */
class Db {
  private static $_instance; //static可以保存值不丟失
  private static $_dbConnect;
  private $_dbConfig = array(
    'host' => '127.0.0.1',
    'user' => 'root',
    'password' => '',
    'database' => 'yii2basic',
  );//保存數據庫的配置信息

  //使用private防止用戶new
  private function __construct(){

  }

  //重寫clone防止用戶進行clone
  public function __clone(){
    //當用戶clone操作時產生一個錯誤信息
    trigger_error("Can't clone object",E_USER_ERROR);
  }  

  //由類的自身來進行實例化 (作者:碼農教程 http://www.manongjc.com )
  public static function getInstance(){
    if(!(self::$_instance instanceof self)){
      self::$_instance = new self();
    }
    return self::$_instance;
  }

  public function connect(){
    self::$_dbConnect = @mysql_connect($this->_dbConfig['host'],
      $this->_dbConfig['user'],$this->_dbConfig['password']);

    if(!self::$_dbConnect){
      throw new Exception("mysql connect error".mysql_error());
      //die("mysql connect error".mysql_error());
    }

    mysql_query("SET NAMES UTF8");
    mysql_select_db($this->_dbConfig['database'],self::$_dbConnect);
    return self::$_dbConnect;
  }
}

$a = Db::getInstance();
try{
  $a->connect();
}catch(Exception $e){
  echo "sorry,error was happend.".$e->getMessage();
}

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved