ホームページ  >  記事  >  バックエンド開発  >  PHP7をベースにしたエラーハンドリングと例外ハンドリングの方法を詳しく解説

PHP7をベースにしたエラーハンドリングと例外ハンドリングの方法を詳しく解説

jacklove
jackloveオリジナル
2018-07-02 18:05:001565ブラウズ

PHP7のエラー処理と例外処理方法(詳細解説)をベースにした記事を以下の編集者が共有するので、非常に参考になり、皆様のお役に立てれば幸いです。エディターに従って見てみましょう

PHP7 エラー処理

PHP 7 では、ほとんどのエラーが報告される方法が変更されました。従来の (PHP 5) エラー報告メカニズムとは異なり、ほとんどのエラーはエラー例外としてスローされるようになりました。

このエラー例外は、例外例外と同様に、最初に一致する try / catch ブロックによってキャッチできます。一致する catch ブロックがない場合は、例外処理関数 (set_Exception_handler() によって事前に登録されている) が処理のために呼び出されます。例外ハンドラーが登録されていない場合は、従来の方法で処理され、致命的エラーとして報告されます。

Error クラスは Exception クラスを継承しないため、catch (Exception e)... を使用して Error をキャッチすることはできません。 catch(Errore) { ... } を使用するか、例外処理関数 (set_Exception_handler()) を登録して Error をキャッチすることができます。

#エラー階層

Throwable
 Error
  ArithmeticError
   pisionByZeroError
  AssertionError
  ParseError
  TypeError
 Exception
  ...

try
{
 // Code that may throw an Exception or Error.
}
catch (Throwable $t)
{
 // Executed only in PHP 7, will not match in PHP 5
}
catch (Exception $e)
{
 // Executed only in PHP 5, will not be reached in PHP 7
}
up
down
9
lubaev dot ka at gmail dot com ¶
11 months ago
php 7.1
try {
 // Code that may throw an Exception or ArithmeticError.
} catch (ArithmeticError | Exception $e) {
 // pass
}

PHP の組み込み例外処理クラスの拡張 (拡張)##ユーザーは、カスタム例外処理クラスを使用して PHP の組み込み例外処理クラスを拡張できます。次のコードは、組み込み例外処理クラスのどのプロパティとメソッドがアクセス可能で、サブクラスによって継承されるかを示しています。

例 1 組み込み例外処理クラス

<?php
class Exception
{
 protected $message = &#39;Unknown exception&#39;; // 异常信息
 private $string;       // __toString cache
 protected $code = 0;      // 用户自定义异常代码
 protected $file;       // 发生异常的文件名
 protected $line;       // 发生异常的代码行号
 private $trace;       // backtrace
 private $previous;      // previous exception if nested exception
 public function __construct($message = null, $code = 0, Exception $previous = null);
 final private function __clone();   // Inhibits cloning of exceptions.
 final public function getMessage();  // 返回异常信息
 final public function getCode();   // 返回异常代码
 final public function getFile();   // 返回发生异常的文件名
 final public function getLine();   // 返回发生异常的代码行号
 final public function getTrace();   // backtrace() 数组
 final public function getPrevious();  // 之前的 exception
 final public function getTraceAsString(); // 已格成化成字符串的 getTrace() 信息
 // Overrideable
 public function __toString();    // 可输出的字符串
}
?>
如果使用自定义的类来扩展内置异常处理类,并且要重新定义构造函数的话,建议同时调用 parent::__construct() 来检查所有的变量是否已被赋值。当对象要输出字符串的时候,可以重载 __toString() 并自定义输出的样式。
 Note:
 Exception 对象不能被复制。尝试对 Exception 对象复制 会导致一个 E_ERROR 级别的错误。

<?php
/**
 * 自定义一个异常处理类
 */
class MyException extends Exception
{
 // 重定义构造器使 message 变为必须被指定的属性
 public function __construct($message, $code = 0, Exception $previous = null) {
  // 自定义的代码
  // 确保所有变量都被正确赋值
  parent::__construct($message, $code, $previous);
 }
 // 自定义字符串输出的样式
 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 is not allowed as a parameter&#39;, 6);
    break;
   default: 
    // 没有异常的情况下,创建一个对象
    $this->var = $avalue;
    break;
  }
 }
}

PHP7のエラー処理と例外処理方法をベースにした上記記事(詳細解説)は編集部が共有した内容ですので、ご参考になれば幸いです、また、皆様にもPHP中国語サイトを応援していただければ幸いです。

#興味があるかもしれない記事:

PHP 学習用の事前定義変数の説明

# #特定の年の週の開始日と終了日を取得する PHP の例

PHP インターフェイスの多重継承と多重継承効果を実現する tarits メソッド


以上がPHP7をベースにしたエラーハンドリングと例外ハンドリングの方法を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。