PHP經典面試題之設計模式(經常遇到)_php執行個體

來源:互聯網
上載者:User

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

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

設計模式非常的多,這裡介紹單例模式,原廠模式,組合模式,策略模式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);

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.