【问题标题】:Should I be throwing different exception types?我应该抛出不同的异常类型吗?
【发布时间】:2013-09-16 09:03:56
【问题描述】:

当故意抛出异常时,我一直只是使用 PHP 的基本 Exception 类,只是带有不同的消息,例如:

<?php
if($a < $b){
  throw new Exception('a is smaller than b');
}elseif($a > $b){
  throw new Exception('a is larger than b');
}

但是,最近我注意到有些人会抛出不同类别的异常,例如:

<?php
if($a < $b){
  throw new aIsSmallerThanBException();
}elseif($a > $b){
  throw new aIsLargerThanBException();
}

这两种方法的优缺点是什么?我应该以第二种方式来做吗?我注意到,在使用 PHPUnit 进行单元测试时,您可以使用 setExpectedException() 告诉它您期待某类异常。这是否意味着第二种方法在使代码可测试方面更好?

谢谢!

【问题讨论】:

  • 请不要在标题中使用伪标签。

标签: php exception-handling phpunit


【解决方案1】:

这些不同的异常可以简化流程,因为您可以一次捕获多种类型的异常。看看这个:

function mustBeEqual($a, $b){
  if($a < $b){
    throw new aIsSmallerThanBException()('a is smaller than b');
  }elseif($a > $b){
    throw new aIsLargerThanBException()('a is larger than b');
  } else {
    //Everything is ok, proceed.
  }
}

try {
  mustBeEqual(3, 4);
} catch (isLargerThanBException $e){
  echo "A is greater than B" ;
} catch (isSmallerThanBException $e){
  echo "A is smaller than B" ;
} catch (Exception e){
  echo "Default exception was triggered: " . $e->getMessage() ;
}

首先,您希望捕获一些特定的异常,然后使用默认异常来确保捕获它。每个特定异常都是Exception 的派生类,并继承getCodegetMessage 等方法。

我也可以给你一个例子:它是如何工作的:

  1. 在 try-catch 块中调用函数。函数抛出异常。
  2. 尝试捕获ConnectionTimeoutException。例外不是这种类型。移至下一个catch
  3. 尝试捕获AccessForbiddenException。这种类型的例外。通知用户该问题。
  4. 我们不移动到下一个捕获,因为异常已经被捕获。就是这样。

【讨论】:

    【解决方案2】:

    这是一个选择性问题。不同的异常类可以由不同的catch 子句处理,因此您可以根据导致异常的原因运行特定的代码。当您有多个嵌套级别的 try-catch 块时,这一点尤其重要。

    另一件事是代码可读性和更容易调试。 OutOfBoundsException 告诉调试人员一些事情,而普通的 Exception 没有。 SPL 定义了一堆有用的exception classes,涵盖了最常见的问题。使用这些 SPL 异常,您可以清楚地传达引发异常的原因。其他人只需查找适当的php.net 页面。

    【讨论】:

      【解决方案3】:

      在使代码可测试方面,您可以使用第二个。优点是一旦存在异常,您就可以在任何脚本中使用该异常。如果是第一个,则每次要使用异常时都应声明像这样throw new Exception('....'); 的新异常。

      【讨论】:

        猜你喜欢
        • 2013-05-20
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2011-05-06
        • 2014-05-02
        • 2019-01-27
        相关资源
        最近更新 更多