Maison > développement back-end > tutoriel php > Explication détaillée des méthodes de gestion des erreurs et des exceptions basées sur PHP7

Explication détaillée des méthodes de gestion des erreurs et des exceptions basées sur PHP7

jacklove
Libérer: 2023-04-02 08:40:01
original
1619 Les gens l'ont consulté

L'éditeur ci-dessous partagera avec vous un article basé sur les méthodes de gestion des erreurs et des exceptions PHP7 (explication détaillée), qui a une bonne valeur de référence et j'espère qu'il sera utile à tout le monde. Suivons l'éditeur pour jeter un œil

Gestion des erreurs PHP7

PHP 7 a changé la façon dont la plupart des erreurs sont signalées. Contrairement au mécanisme de rapport d'erreurs traditionnel (PHP 5), la plupart des erreurs sont désormais générées en tant qu'exceptions d'erreur.

Cette exception Error peut être interceptée par le premier bloc try/catch correspondant, tout comme l'exception Exception. S'il n'y a pas de bloc catch correspondant, la fonction de gestion des exceptions (précédemment enregistrée via set_exception_handler()) est appelée pour le traitement. Si un gestionnaire d'exceptions n'a pas été enregistré, il est traité de manière traditionnelle : il est signalé comme une erreur fatale.

La classe Error n'hérite pas de la classe Exception, vous ne pouvez donc pas utiliser catch (Exception e)... pour intercepter Error. Vous pouvez utiliser catch(Errore) { ... }, ou catch Error en enregistrant une fonction de gestion des exceptions (set_exception_handler()).

Hiérarchie des erreurs

Throwable
 Error
  ArithmeticError
   pisionByZeroError
  AssertionError
  ParseError
  TypeError
 Exception
  ...
Copier après la connexion

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
}
Copier après la connexion

Étendre la classe de gestion des exceptions intégrée de PHP

Les utilisateurs peuvent utiliser des classes de gestion des exceptions personnalisées pour étendre la classe de traitement des exceptions intégrée de PHP. Le code suivant illustre quelles propriétés et méthodes de la classe de gestion des exceptions intégrée sont accessibles et héritées par les sous-classes.

Exemple n°1 Classe de gestion des exceptions intégrée

<?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 级别的错误。
Copier après la connexion

<?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;
  }
 }
}
Copier après la connexion

L'article ci-dessus basé sur les méthodes de gestion des erreurs et des exceptions PHP7 (explication détaillée) est tout le contenu partagé par l'éditeur, j'espère qu'il pourra vous donner une référence, et j'espère que vous prendrez en charge le chinois PHP. site web.

Articles qui pourraient vous intéresser :

Explication des variables prédéfinies pour l'apprentissage du PHP

Explication de PHP obtenant la date de début et la date de fin de la semaine d'une certaine année

Comment obtenir un effet multi-héritage grâce à l'interface PHP, à l'héritage multiple et aux compétences tarits_php

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal