接著完善自己的PHP框架,本次更新的主要內容有:
異常處理:異常處理是編程語言或計算機硬件裡的一種機制,用於處理軟件或信息系統中出現的異常狀況(即超出程序正常執行流程的某些特殊條件)
異常處理用於處理程序中的異常狀況,雖說是“異常狀態”,但仍然還是在程序編寫人員的預料之中,其實程序的異常處理完全可以用‘if else’語句來代替,但異常處理自然有其優勢之處。
個人總結其優點如下:
雖然將代碼放在try catch塊中會有微微的效率差,但是跟這些優點一比,這點消耗就不算什麼了。那麼PHP的異常處理怎麼使用呢?
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語句,需要注意:
說了那麼多異常相關(當然解釋這些也是為了能理解和使用框架),那麼框架裡要怎麼實現呢?
我們可以重寫異常類,完善其內部方法:
<?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
來記錄一個異常日志了。
我們可以使用set_exception_handler('exceptionHandler')來全局捕獲沒有被catch塊捕獲到的異常,此異常處理函數需要傳入一個異常處理對象,這樣可以分析此異常處理信息,避免系統出現不人性化的提示,增強框架的健壯性。
function exceptionHandler($e) {
echo '有未被捕獲的異常,在' . $e->getFile() . "的" . $e->getLine() . "行!";
}
順便再說一下其他的全局處理函數:
但是要注意這些全局函數需要在代碼段的前面已經定義過再注冊。
初次使用yii2的ActivceRecord類覺得好方便,只需要定義其字段同名屬性再調用save方法就OK了(好神奇啊),它是怎麼實現的呢,看了下源碼,明白了其大致實現過程(基類)。
感覺好久沒寫博客了,‘畢業’對於一個類似專科學習方式的人來說是有些繁瑣了,保存好對學校的留戀,繼續出發。
真是越學習越覺得自己認識不夠,在看一些PHP框架源碼時,有時候會感覺自己還差得很遠,那種整體感和布局感,估計需要時間和經驗的積累吧。
因為框架的應用和自己現在的工作關系不是特別大,而且自己最近在努力學習一些編程底層類的東西,所以框架系列可能會有些‘便秘’,會寫點其他的。。。這兩天准備換地方住了,跑著看房子了,原諒我‘短’一點。。
哈哈,歡迎繼續關注我的博客,嗯,一直在用心。