
本文旨在解决在循环中调用可能抛出异常的方法时,如何优雅地处理异常并继续迭代的问题。由于直接在外部 try-catch 块中使用 continue 跳过特定元素不可行,我们将探讨一种替代方案,即通过构建自定义类来解决该问题,该类能返回相同的别名而不会抛出异常。
当你在循环中调用一个方法,而该方法在某些情况下会抛出异常,并且你希望在捕获异常后继续循环,直接的 try-catch 结构可能无法满足需求,尤其是在无法修改原始方法代码的情况下。
考虑以下场景(基于提供的代码示例):
一个类包含一个私有方法 getAliasesFilters(),该方法内部有一个循环,循环过程中可能会抛出 FilterException 异常。
private function getAliasesFilters(): array{ $filters = ...; // 假设这里从某个地方获取了 $filters 数据 $aliasesFilters = array(); if (is_array($filters)) { foreach ($filters as $filter) { if (array_key_exists($filter['alias'], $aliasesFilters)) { $msg = sprintf( 'More than one filter with an alias "%s "was found!', $filter['alias'] ); throw new FilterException($msg, FilterException::MULTIPLE_ALIAS); } $aliasesFilters[$filter['alias']] = $filter['filter_id']; } } return $aliasesFilters;}
这个方法被另一个方法 getFilters() 调用:
public function getFilters(): array{ $filters = $this->getAliasesFilters(); foreach ($filters as $alias => $id) { $filters[$alias] = new FilterDefiniton($id); } return $filters;}
现在,在其他类中调用 getFilters(),并且希望在捕获 FilterException 异常后,能够继续迭代,跳过导致异常的元素。但是,由于异常是在 getAliasesFilters() 方法内部抛出的,无法直接在外部 try-catch 块中使用 continue 语句。
解决方案:构建自定义类
由于无法修改原始类(包含 getAliasesFilters() 和 getFilters() 方法)的代码,一种可行的解决方案是创建一个自定义类,该类能够返回相同的数据,但避免抛出异常。
分析异常原因: 首先,需要深入了解 FilterException 异常抛出的原因。根据代码,异常是由于在 $filters 数组中存在重复的 alias 导致的。
创建自定义类: 创建一个新的类,用于替代原始类,或者作为原始类的装饰器。在这个自定义类中,重新实现 getAliasesFilters() 方法,但这次要避免抛出异常。
class CustomFilterHandler{ private $originalFilterClass; // 原始类的实例 public function __construct($originalFilterClass) { $this->originalFilterClass = $originalFilterClass; } public function getFilters(): array { $filters = $this->getSafeAliasesFilters(); // 调用自定义的 getSafeAliasesFilters 方法 foreach ($filters as $alias => $id) { $filters[$alias] = new FilterDefiniton($id); // 假设 FilterDefiniton 类存在 } return $filters; } private function getSafeAliasesFilters(): array { $filters = ...; // 从与原始类相同的数据源获取 $filters 数据 $aliasesFilters = array(); if (is_array($filters)) { foreach ($filters as $filter) { if (array_key_exists($filter['alias'], $aliasesFilters)) { // 记录日志,或者执行其他处理,但不要抛出异常 error_log(sprintf('Duplicate alias "%s" found, skipping.', $filter['alias'])); continue; // 跳过重复的 alias } $aliasesFilters[$filter['alias']] = $filter['filter_id']; } } return $aliasesFilters; }}
使用自定义类: 在调用 getFilters() 的地方,使用自定义类的实例来替代原始类的实例。
$originalObject = new OriginalFilterClass(); // 原始类的实例$customHandler = new CustomFilterHandler($originalObject);$this->filters = $customHandler->getFilters(); // 调用自定义类的 getFilters 方法
代码解释:
CustomFilterHandler 类接收原始类的实例作为参数,这使得它可以访问原始类的数据源。getSafeAliasesFilters() 方法与原始的 getAliasesFilters() 方法类似,但它不会抛出异常。相反,它会记录重复的 alias,并使用 continue 语句跳过该元素,从而继续循环。getFilters() 方法调用 getSafeAliasesFilters() 方法,然后执行与原始类相同的后续处理。
注意事项:
需要确保自定义类能够访问与原始类相同的数据源。在 getSafeAliasesFilters() 方法中,需要选择合适的异常处理方式,例如记录日志、发送通知等。避免直接忽略错误,确保能够及时发现和解决问题。这种方法实际上是在避免异常的抛出,而不是真正地处理异常。因此,需要仔细考虑是否适合特定的应用场景。如果必须处理异常,可能需要采用其他更复杂的解决方案,例如修改原始类的代码,或者使用更高级的异常处理机制。
总结:
虽然无法直接在外部 try-catch 块中使用 continue 语句来跳过循环中的特定元素,但可以通过构建自定义类来避免异常的抛出,从而实现类似的效果。这种方法需要在原始类无法修改的情况下,通过创建一个新的类来替代原始类的行为。在自定义类中,需要仔细处理可能导致异常的情况,例如记录日志、发送通知等。
以上就是在循环中处理抛出异常的方法并继续迭代的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1270061.html
微信扫一扫
支付宝扫一扫