
本文探讨了在循环中调用可能抛出异常的方法时,如何优雅地处理异常并继续迭代的问题。由于无法直接在调用方法外部使用continue跳过特定元素,本文将提供一种通过构建自定义类和函数来规避异常,从而实现迭代继续的解决方案。
由于无法直接修改抛出异常的类中的代码,并且需要在调用方处理异常并继续迭代,最可行的方案是创建一个自定义类,该类复制了原类的部分逻辑,但能够处理潜在的异常情况,并返回可迭代的数据。
核心思路:
示例代码:
假设原类名为OriginalClass,包含getAliasesFilters()和getFilters()方法。
class CustomFilterHandler
{
private $data; // 假设这里存储了原始数据,例如从数据库获取
public function __construct($data) {
$this->data = $data;
}
public function getSafeAliasesFilters(): array
{
$aliasesFilters = array();
$errors = []; // 用于存储错误信息
if (is_array($this->data)) {
foreach ($this->data as $filter) {
try {
if (array_key_exists($filter['alias'], $aliasesFilters)) {
$msg = sprintf(
'More than one filter with an alias "%s "was found!',
$filter['alias']
);
// 记录错误信息,而不是抛出异常
$errors[$filter['alias']] = $msg;
continue; // 跳过当前元素,继续迭代
}
$aliasesFilters[$filter['alias']] = $filter['filter_id'];
} catch (Exception $e) {
// 处理其他可能的异常
$errors[$filter['alias']] = "Unexpected error: " . $e->getMessage();
}
}
}
return ['filters' => $aliasesFilters, 'errors' => $errors];
}
}调用示例:
// 假设 $originalData 是从某个地方获取的原始数据
$handler = new CustomFilterHandler($originalData);
$result = $handler->getSafeAliasesFilters();
$filters = $result['filters'];
$errors = $result['errors'];
foreach ($filters as $alias => $id) {
// 如果有错误,则记录或采取其他措施
if (isset($errors[$alias])) {
// 记录错误日志
error_log("Error processing alias {$alias}: " . $errors[$alias]);
// 或者采取其他补救措施
continue; // 跳过当前别名
}
// 如果没有错误,则继续处理
$filters[$alias] = new FilterDefiniton($id);
}
// 现在 $filters 包含了经过处理的 FilterDefiniton 数组,并且已经处理了潜在的错误注意事项:
总结:
虽然无法直接在调用方使用continue跳过异常元素,但通过构建自定义类和函数,可以在内部处理异常,并将错误信息传递给调用方。这样,调用方就可以根据错误信息进行相应的处理,并继续迭代,从而实现所需的功能。这种方法虽然需要额外的工作量,但可以在不修改原始代码的情况下,解决特定问题。
以上就是在循环中处理异常并继续迭代的方案的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号