程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> PHP經典面試題之設計模式(經常遇到)

PHP經典面試題之設計模式(經常遇到)

編輯:PHP綜合

設計模式在面試過程中經常會提到,有時候還會讓我們舉例說明各種設計模式的應用場景。

使用設計模式可以減輕我們的工作量,優化我們的代碼。

設計模式非常的多,這裡介紹單例模式,工廠模式,組合模式,策略模式4種模式

如果有代碼有什麼問題或者有更好的方式請告知,謝謝!!!!!

/**
 * 單例模式
 * @author YangYang <[email protected]>
 * 可以想成在一次http請求中只產生該類的一個對象(即只new classname一次)
 * 經典的例子是數據庫連接(redis,mongodb,memcache等)
 * 在一次http請求中我們可能需要對數據庫做增刪改查多條sql操作
 * 但是如果一次http請求中每執行一條sql我們就mysql_connect(),很明顯會導致服務器資源的浪費
 * 為了節約資源,就可以通過單例模式來實現一次http請求只做一次mysql_connect()
 * 即將mysql_connect()放在類方法的__construct中,並將__construct方法做成私有,
 * 這樣只能通過getInstance()方法來獲得mysql_connect()的資源連接符
 * getInstance()方法中判斷是否已經存在myql連接符,如果存在就直接返回該連接符
 * 否則new classname()即調用了__construct方法執行了mysql_connect()得到了資源連接符,並返回連接符
 * 因為現在PHP已不再建議直接使用mysql函數進行數據庫操作,而是建議通過PDO進行數據庫操作,所以這裡寫一個簡易PDO連接的單例模式
 * 這裡只是講解單例原理,數據庫的防sql注入等問題不做考慮
 * 准備工作 數據庫:test 數據表:user 字段:id name 記錄:1 CodeAnti
 * 最終運行結果: 數據表user中id=1這條記錄被刪除
 */
class SinglePDO
{
    private static $_instance = null;
    private $_pdo;
    //私有,防止外部直接實例化new SinglePDO(...)
    private function __construct($dsn,$dbUser,$dbPassword)
    {
        try{
            $this->_pdo = new PDO($dsn,$dbUser,$dbPassword);
            $this->_pdo->exec('set names utf8');
        }catch(PDOException $e){
            die("Error:{$e->getMessage()}");
        }
    }
    //私有,防止克隆
    private function __clone(){}
    //獲取連接實例
    public static function getInstance($dsn,$dbUser,$dbPassword)
    {
        if(self::$_instance === null)
            self::$_instance = new self($dsn,$dbUser,$dbPassword);
        return self::$_instance;
    }
    //執行sql
    public function execSql($sql)
    {
        $result = $this->_pdo->exec($sql);
        return $result;
    }
}

$dsn = "mysql:host=localhost;dbname=test";
$dbUser = "root";
$dbPassword = "";
$sql = "delete from user where id = 1";
$pdo = SinglePDO::getInstance($dsn,$dbUser,$dbPassword);
$result = $pdo->execSql($sql); //$pdo->execSql($sql)多次調用,但仍然是同一個pdo對象
print_r($result);

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