首頁 > 後端開發 > php教程 > 擴展 php 內建的異常處理類

擴展 php 內建的異常處理類

伊谢尔伦
發布: 2016-11-23 09:13:46
原創
1102 人瀏覽過

用戶可以用自訂的異常處理類別來擴充 PHP 內建的異常處理類別。以下的程式碼說明了在內建的異常處理類別中,哪些屬性和方法在子類別中是可存取和可繼承的。譯者註:以下這段程式碼只為說明內建異常處理類別的結構,它並不是一段有實際意義的可用程式碼。

Example #1 內建的異常處理類

<?php
    class Exception
    { 
        protected $message = &#39;Unknown exception&#39;; // 异常信息
        protected $code = 0; // 用户自定义异常代码
        protected $file; // 发生异常的文件名
        protected $line; // 发生异常的代码行号
        function __construct($message = null, $code = 0);
        final function getMessage(); // 返回异常信息
        final function getCode(); // 返回异常代码
        final function getFile(); // 返回发生异常的文件名
        final function getLine(); // 返回发生异常的代码行号
        final function getTrace(); // backtrace() 数组
        final function getTraceAsString(); // 已格成化成字符串的 getTrace() 信息
        /* 可重载的方法 */
        function __toString(); // 可输出的字符串
}
?>
登入後複製

如果使用自訂的類別來擴展內建異常處理類,並且要重新定義建構函數的話,建議同時調用 parent::__construct() 來檢查所有的變數是否已被賦值。當物件要輸出字串的時候,可以重載 __toString() 並自訂輸出的樣式。

Example #2 擴充 PHP 內建的異常處理類別

<?php
    /**
     * 自定义一个异常处理类
     */
    class MyException extends Exception
    {
        // 重定义构造器使 message 变为必须被指定的属性
        public function __construct($message, $code = 0) {
            // 自定义的代码
            // 确保所有变量都被正确赋值
            parent::__construct($message, $code);
        }
        // 自定义字符串输出的样式
        public function __toString() {
            return __CLASS__ . ": [{$this->code}]: {$this->message}\n";
        }
        public function customFunction() {
            echo "A Custom function for this type of exception\n";
        }
    }
    /**
     * 创建一个用于测试异常处理机制的类
     */
    class TestException
    {
        public $var;
        const THROW_NONE = 0;
        const THROW_CUSTOM = 1;
        const THROW_DEFAULT = 2;
        function __construct($avalue = self::THROW_NONE) {
            switch ($avalue) {
                case self::THROW_CUSTOM:
                    // 抛出自定义异常
                    throw new MyException(&#39;1 is an invalid parameter&#39;, 5);
                    break;
                case self::THROW_DEFAULT:
                    // 抛出默认的异常
                    throw new Exception(&#39;2 isnt allowed as a parameter&#39;, 6);
                    break;
                default:
                    // 没有异常的情况下,创建一个对象
                    $this->var = $avalue;
                    break;
            }
        }
    }
    // 例子 1
    try {
        $o = new TestException(TestException::THROW_CUSTOM);
    } catch (MyException $e) { // 捕获异常
        echo "Caught my exception\n", $e;
        $e->customFunction();
    } catch (Exception $e) { // 被忽略
        echo "Caught Default Exception\n", $e;
    }
    // 执行后续代码
    var_dump($o);
    echo "\n\n";
    // 例子 2
    try {
        $o = new TestException(TestException::THROW_DEFAULT);
    } catch (MyException $e) { // 不能匹配异常的种类,被忽略
        echo "Caught my exception\n", $e;
        $e->customFunction();
    } catch (Exception $e) { // 捕获异常
        echo "Caught Default Exception\n", $e;
    }
    // 执行后续代码
    var_dump($o);
    echo "\n\n";
    // 例子 3
    try {
        $o = new TestException(TestException::THROW_CUSTOM);
    } catch (Exception $e) { // 捕获异常
        echo "Default Exception caught\n", $e;
    }
    // 执行后续代码
    var_dump($o);
    echo "\n\n";
    // 例子 4
    try {
        $o = new TestException();
    } catch (Exception $e) { // 没有异常,被忽略
        echo "Default Exception caught\n", $e;
    }
    // 执行后续代码
    var_dump($o);
    echo "\n\n";
?>
登入後複製


相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板