[PHP] Trigger_error 趣谈

来源:互联网 发布:社交网络营销策划方案 编辑:程序博客网 时间:2024/05/22 03:29

最近在debug时,发现一个很有趣的关于Trigger_error用法的问题。

该bug的表象是程序在生成某条重要业务数据之前突然断了,所以我就一路追代码,一直追到非常底层的位置,才抓住了代码断掉的位置。在这里并没有看到常见的程序中断的指令,如die(), exit()等。而是看到了如下代码:

trigger_error('age you input must>=0',E_USER_ERROR); 

由于对trigger_error语法不熟悉,遂和同事讨论为何代码会断在这里。同事纷纷尝试如下写法:

trigger_error('age you input must>=0'); 

trigger_error('age you input must>=0',E_USER_WARNING); 

trigger_error('age you input must>=0',E_USER_NOTICE);

最终发现,以上三种写法都不会中断程序的运行,只是会有一行Warning提示。而只有E_USER_ERROR会将程序立刻中断。在翻阅了众多博客和文章后找到W3C中的一段解释(链接:http://www.w3school.com.cn/php/php_ref_error.asp):

E_USER_ERROR类似于E_ERROR,区别处在于E_USER_ERROR是在代码中由trigger_error方法产生的。但其原理都相同,即:“运行时致命的错误。不能修复的错误。终止执行脚本。”

这也使得我们反思了日常工作中对trigger_error的使用,尤其需要注意第二个参数的使用。因为一旦使用E_USER_ERROR,在抛出错误时,程序也会随之中断,从而产生业务流程中断等问题。

最终,因为有不同的业务场景会走到该段代码,有一些业务场景确实是需要在这里进行立刻中断的,所以我们只在我们发现问题的业务场景上进行了前置错误处理,使得类似的error在被trigger之前即被处理掉。



1 0
原创粉丝点击