亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

php  單例模式詳細介紹及實現(xiàn)源碼

 更新時間:2016年11月05日 11:59:01   投稿:lqh  
這篇文章主要介紹了php 單例模式詳細介紹及實現(xiàn)源碼的相關(guān)資料,需要的朋友可以參考下

這篇文章主要介紹了PHP中數(shù)據(jù)庫單例模式的實現(xiàn)代碼分享,本文先是講解了單例模式的一些知識,然后給出了數(shù)據(jù)庫單例模式實現(xiàn)代碼。

什么是單例模式

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

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

單例模式的要點有三個:

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

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

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

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

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

單例類

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

2、擁有一個保存類的實例的靜態(tài)成員變量

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

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

php單例模式實現(xiàn)方法

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

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

同時,為了防止用戶去new實例,需要將“__construct”函數(shù)權(quán)限設(shè)置為private。

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

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

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

  }

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

  //由類的自身來進行實例化 (作者:碼農(nóng)教程 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();
}

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

相關(guān)文章

最新評論