>백엔드 개발 >PHP 튜토리얼 >PHP에 내장된 예외 처리 클래스 확장

PHP에 내장된 예외 처리 클래스 확장

伊谢尔伦
伊谢尔伦원래의
2016-11-23 09:13:461098검색

사용자는 사용자 정의 예외 처리 클래스를 사용하여 PHP에 내장된 예외 처리 클래스를 확장할 수 있습니다. 다음 코드는 기본 제공 예외 처리 클래스의 어떤 속성과 메서드가 하위 클래스에서 액세스하고 상속 가능한지 보여줍니다. 번역자 주: 다음 코드는 내장된 예외 처리 클래스의 구조를 설명하기 위한 것일 뿐입니다. 실제적으로 의미가 있는 사용 가능한 코드는 아닙니다.

예제 #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(); // 可输出的字符串
}
?>

사용자 정의 클래스를 사용하여 내장 예외 처리 클래스를 확장하고 생성자를 재정의하는 경우 부모 호출을 권장합니다. :: 동시에 __construct()를 사용하여 모든 변수에 값이 할당되었는지 확인합니다. 객체가 문자열을 출력하려는 ​​경우 __toString()을 오버로드하고 출력 스타일을 사용자 정의할 수 있습니다.

예제 #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";
?>


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.