設計模式在面試過程中經常會提到,有時候還會讓我們舉例說明各種設計模式的應用情境。
使用設計模式可以減輕我們的工作量,最佳化我們的代碼。
設計模式非常的多,這裡介紹單例模式,原廠模式,組合模式,策略模式4種模式
如果有代碼有什麼問題或者有更好的方式請告知,謝謝!!!!!
/** * 單例模式 * @author YangYang <1812271619@qq.com> * 可以想成在一次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);