您好,登錄后才能下訂單哦!
這篇文章主要介紹“PHP有哪些設計模式”,在日常操作中,相信很多人在PHP有哪些設計模式問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”PHP有哪些設計模式”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
設計模式非常的多,這里介紹單例模式,工廠模式,組合模式,策略模式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);
到此,關于“PHP有哪些設計模式”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。