搭建本身的PHP框架心得(三)

續言

接着完善本身的PHP框架,本次更新的主要內容有:php

  • 介紹了異常處理機制
  • 完善了異常和錯誤處理
  • 數據表跟Model類的映射

異常處理

異常處理:異常處理是編程語言或計算機硬件裏的一種機制,用於處理軟件或信息系統中出現的異常情況(即超出程序正常執行流程的某些特殊條件)html

異常處理用於處理程序中的異常情況,雖然說是「異常狀態」,但仍然仍是在程序編寫人員的預料之中,其實程序的異常處理徹底能夠用‘if else’語句來代替,但異常處理天然有其優點之處。git

我的總結其優勢以下:github

  • 能夠快速終止流程,重置系統狀態,清理變量和內存佔用,在普通WEB應用中,一次請求結束後,FAST CGI會自動清理變量和上下文,但若是在PHP的命令行模式執行守護腳本時,它的效果就會很方便了。
  • 大量的if else語句會使代碼變得繁雜難懂,使用異常處理可使程序邏輯更清晰易懂,畢竟處理異常的入口只有catch語句一處。
  • 一量程序中的函數出現異常結果或情況,若是使用函數的return方式返回異常信息,層層向上,每一次都要進行return判斷。使用異常處理咱們能夠假設全部的返回信息都是正常的,避免了大量的代碼重複。

雖然將代碼放在try catch塊中會有微微的效率差,可是跟這些優勢一比,這點消耗就不算什麼了。那麼PHP的異常處理怎麼使用呢?web

PHP內置有Exception類,使得咱們能夠經過實例化異常類來拋出異常。咱們將代碼放在try語句中執行,並在其後用catch試圖捕捉到在try代碼塊中拋出的異常,並對異常進行處理。咱們還能夠在catch代碼段後使用finally語句塊,不管是否有異常都會執行finally代碼塊的代碼,try catch語句形以下面代碼:編程

try{
    throw new Exeption('msg'[,'code',$previous_exeception]);
}catch(Exeption $var) {
    process($var);
}catch(MyException $e){
    process($e)
}finally{
    dosomething();
}

使用try catch語句,須要注意:canvas

  • 當咱們拋出異常時,會實例化一個異常類,此異常類能夠本身定義,但在catch語句中,咱們須要規定要捕獲的異常對象的類名,而且只能捕獲到特定類的異常對象,固然咱們能夠在最後捕獲一個異常基類(PHP內置異常類)來確保異常必定能被捕獲。
  • 在拋出異常時,程序會被終止,並回溯代碼找到第一個能捕獲到它的catch語句,try catch語句是能夠嵌套的,而且如上面代碼所示 cacth語句是能夠屢次定義的。
  • finally塊會在try catch塊結束後執行,即便在try catch塊中使用return返回,程序沒有執行到最後。

框架裏的異常處理

說了那麼多異常相關(固然解釋這些也是爲了能理解和使用框架),那麼框架裏要怎麼實現呢?數組

重寫異常類

咱們能夠重寫異常類,完善其內部方法:ruby

<?php  
class Exception  
{  
    protected $message = 'Unknown exception';   // 異常信息  
    protected $code = 0;                        // 異常代碼  
    protected $file;                            // 發生異常的文件名  
    protected $line;                            // 發生異常的代碼行號  

    function __construct($message = null, $code = null,$previous_exeception = null);  

    final function getMessage();                // 返回異常信息  
    final function getCode();                   // 返回異常代碼  
    final function getFile();                   // 返回發生異常的文件名  
    final function getLine();                   // 返回發生異常的代碼行號  
    final function getTrace();                  // 返回異常trace數組  
    final function getTraceAsString();          // 返回異常trace信息

    /**
     * 記錄錯誤日誌
     */
    protected function log(){
        Logger::debug();
    }
}

如上,final方法是不能夠重寫的,除此以外,咱們能夠定義本身的方法,如記錄異常日誌,像我自定義的log方法,在catch代碼塊中,就能夠直接使用$e->log來記錄一個異常日誌了。yii2

註冊全局異常方法

咱們可使用set_exception_handler('exceptionHandler')來全局捕獲沒有被catch塊捕獲到的異常,此異常處理函數須要傳入一個異常處理對象,這樣能夠分析此異常處理信息,避免系統出現不人性化的提示,加強框架的健壯性。

function exceptionHandler($e) {
    echo '有未被捕獲的異常,在' . $e->getFile() . "的" . $e->getLine() . "行!";
}

其餘全局函數

順便再說一下其餘的全局處理函數:

  • set_shutdown_function('shutDownHandler')來執行腳本結束時的函數,此函數即便是在ERROR結束後,也會自動調用。
  • set_error_handler('errorHandler')在PHP發生錯誤時自動調用,注意,必須在已註冊錯誤函數後才發出的錯誤纔會調用。函數參數形式應爲($errno, $errstr, $errfile, $errline);

可是要注意這些全局函數須要在代碼段的前面已經定義過再註冊。


數據表和Model類的ActiveRecord映射

初次使用yii2的ActivceRecord類以爲好方便,只須要定義其字段同名屬性再調用save方法就OK了(好神奇啊),它是怎麼實現的呢,看了下源碼,明白了其大體實現過程(基類)。

  1. 使用‘describe table_name’ 查詢語句;
  2. 分析查詢結果:對每個字段,有Field(字段名)、Type(數據類型)、Null(是否爲空)、Key(索引信息,‘PRI’表示爲主鍵)、Default(默認值)、Extra(附加信息,如auto_increment)
  3. 經過判斷其主鍵($row['KEY'] == 'PRI')信息,保存時看是否有主鍵信息,若存在,則爲更新;不存在,則插入。
  4. 另外,解析出來的字段信息還有更多妙用~~

結語

感受很久沒寫博客了,‘畢業’對於一個相似專科學習方式的人來講是有些繁瑣了,保存好對學校的留戀,繼續出發。

真是越學習越以爲本身認識不夠,在看一些PHP框架源碼時,有時候會感受本身還差得很遠,那種總體感和佈局感,估計須要時間和經驗的積累吧。

由於框架的應用和本身如今的工做關係不是特別大,並且本身最近在努力學習一些編程底層類的東西,因此框架系列可能會有些‘便祕’,會寫點其餘的。。。這兩天準備換地方住了,跑着看房子了,原諒我‘短’一點。。

哈哈,歡迎繼續關注個人博客,嗯,一直在用心。

相關文章
相關標籤/搜索