PHP错误级别详解

在PHP开发的时候常常会用到error_reporting(report_level)来调试自己的程序,下面列出了report_level可能值:

常量描述
1E_ERROR这是一个严重错误,不可恢复,如位置异常,内存不足等
2E_WARNING警告,最一般的错误,如函数的参数错误等
4E_PARSE解析错误,在解析PHP文件时产生,并强制PHP在执行前退出
8E_NOTICE通告表示可能在操作一些未知的变量等。在开发时可开启通告,以保证程序是"安全通告"的,瑞在正式系统中,应关闭通告
16E_CORE_ERROR这个内部错误是由于PHP加载扩展失败而导致的,并且会导致PHP停止运行并退出
32E_CORE_WARNINGPHP启动时初始化过程中的警告(非致命性错)
64E_COMPILE_ERROR编译错误是在编译时发生,这个错误将导致PHP运行退出
128E_COMPILE_WARNING编译警告用于告诉用户一些不推荐的语法信息
256E_USER_ERROR用户定义的错误将导致辞PHP退出,它对是来自PHP自身,而是来自脚本文件中。
512E_USER_WARNING脚本使用它来通知一个执行失败,同时PHP也会用E_WARNING通知
1024E_USER_NOTICE用户定义的通告用于在脚本中表示可能存在的错误
2048E_STRICT编码标准化警告(建议如何修改以向前兼容)
4096E_RECOVERABLE_ERROR接近致命的运行时错误,若未被捕获则视同E_ERROR
8191E_ALL除E_STRICT外的所有错误(PHP6中为8191,即包含所有)

例子:

任意数目的以上选项都可以用“或”来连接(用 OR 或 |),这样可以报告所有需要的各级别错误。例如,下面的代码关闭了用户自定义的错误和警告,执行了某些操作,然后恢复到原始的报错级别:

<?php
//禁用错误报告
error_reporting(0);

//报告运行时错误
error_reporting(E_ERROR | E_WARNING | E_PARSE);   

//报告所有错误
error_reporting(E_ALL);   

error_reporting(7);
/*
设置php错误检测级别
E_ERROR - 致命性运行时错 (1)
E_WARNING - 运行时警告(非致命性错)(2)
E_PARSE - 编译时解析错误 (4)
1+2+4 = 7
*/
?>
我们熟悉的uchome系统中的调试处理就采用了以下错误检测级别:
D_BUG ? error_reporting(7) : error_reporting(0);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CAN(Controller Area Network)总线是一种串行通信协议,用于在汽车和工业设备中进行故障诊断、数据交换等。在CAN总线中,错误帧是网络通信过程中用来检测和处理错误的一种机制。以下是CAN错误帧的一些关键详解: 1. **错误类型**: - CRC(循环冗余检查)错误:当接收到的帧的CRC校验码不正确时,发送器将产生一个错误帧。 - 形式错误:如果帧格式不符合规定(如不正确的帧ID、比特速率标志等),也会导致错误帧。 - 填充位错误:在接收过程中,如果填充位(为了保持奇偶性而添加的额外位)与期望不符,会产生错误。 2. **错误帧结构**: - 数据段1和数据段2:错误帧通常由两个数据段组成,即使在没有数据传输时也是如此,以保留错误标识的格式。 - 帧ID:错误帧的帧ID通常是特殊值,如0x7FF或0xFFF,表示一个错误条件。 - 优先级标志(RTR):在错误帧中,RTR位通常为1,表示这是一个远程帧请求,而非标准的数据帧。 3. **错误处理**: - 发送者识别:错误帧可以由发送者发送,表明它自己发送的信息有问题;或者由接收者发送,表示它收到了不正确的数据。 - 跳过机制:CAN设备在接收到错误帧后,可以选择跳过当前的帧重试发送,或者进入一种“静默”模式,直到网络恢复稳定。 4. **错误帧检测**: - 过滤器:CAN控制器支持错误帧过滤,可以根据预定义的错误严重程度对错误进行处理,避免频繁的错误警告。 相关问题: 1. CAN总线如何确认错误发生? 2. 如何配置CAN节点来处理错误帧? 3. CAN错误帧的处理流程是什么?

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值