[英]Catch a fatal exception and continue
我知道,根据它的定义,一个致命的异常应该杀死执行,不应该被压制,但这是问题所在。
我正在运行一个脚本,在数据库中擦除,解析和存储大约10,000页。 这需要几个小时,在极少数情况下(1000个中有1个)页面无法解析并抛出致命异常。
目前,我这样做:
for ($i=0;$i<$count;$i++)
{
$classObject = $classObjects[$i];
echo $i . " : " . memory_get_usage(true) . "\n";
$classDOM = $scraper->scrapeClassInfo($classObject,$termMap,$subjectMap);
$class = $parser->parseClassInfo($classDOM);
$dbmanager->storeClassInfo($class);
unset($classDOM,$class,$classObject);
}
我能做点什么吗
for ($i=0;$i<$count;$i++)
{
$classObject = $classObjects[$i];
echo $i . " : " . memory_get_usage(true) . "\n";
try
{
$classDOM = $scraper->scrapeClassInfo($classObject,$termMap,$subjectMap);
$class = $parser->parseClassInfo($classDOM);
$dbmanager->storeClassInfo($class);
unset($classDOM,$class,$classObject);
}
catch (Exception $e)
{
//log the error here
continue;
}
}
上面的代码不适用于fatal exceptions
。
是否可以执行以下操作:如果我将主循环移动到方法中,然后从register_shutdown_function
调用该方法?
像这样:
function do($start)
{
for($i=$start;$i<$count;$i++)
{
//do stuff here
}
}
register_shutdown_function('shutdown');
function shutdown()
{
do();
}
这是执行停止时输出的消息:
Fatal error: Call to a member function find() on a non-object in ...
当我正在使用的方法无法解析页面时,我希望上面的消息。 我很好,只是跳过该页面并继续循环的下一次迭代。
致命错误是致命的并终止执行。 如果发生致命错误,则无法解决此问题。 但是,你的错误:
致命错误:在...中的非对象上调用成员函数find()
是完全可以预防的。 只需添加一个检查以确保您拥有正确对象的实例,如果没有,则处理错误:
if ($foo instanceof SomeObject) {
$foo->find(...);
} else {
// something went wrong
}
我遇到了类似的问题,我发现在find()调用之前使用is_object()调用可以避免致命错误。
在我看来,“捕捉”一个错误的唯一可能的方法就是注册一个关机功能。 请记住将所有(或可能是一组)查询添加到事务中,如果出现故障可能会将其回滚,以确保一致性。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.