設計模式在面試過程中經常會提到,有時候還會讓我們舉例說明各種設計模式的應用場景。
使用設計模式可以減輕我們的工作量,優化我們的代碼。
設計模式非常的多,這裡介紹單例模式,工廠模式,組合模式,策略模式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);