PHP 程序员也要学会使用“异常”


Posted in PHP onJune 16, 2009

网站完全开放的特性,决定了网站比任何传统软件都更希望做到“系统看起来永远都是能够正常工作的”,所以采用正确的程序错误处理方式尤为重要。理论上来说,如果设计足够完美,开发人员足够谨慎,程序出现错误的可能为0.
但事实恰恰相反,复杂的业务逻辑,不同的硬件环境,或者不可信任的用户输入,都可能导致程序出错,服务当机。所以在稍微有点复杂的系统中,有个完善的错误机制是必须的。
在php5之前,因为缺乏对异常的支持。在做复杂的开发时,常常采取比较原始的“处理错误数值+记录log”的处理形式。
如:

function getResult($a,$b) 
{ 
....... 
if fatal error occur 
return "error_type1"; 
..... 
} 
$result = getResult($a,$b);//理论上,getResult函数总能正确的返回$result 
if($result=='error_type1')//但在一些特殊情况.$result无法正常取得 
{ 
writeLog('result is empty!');//记录下log 
die();//或者其他更“友好的”处理方式 
}

理论上,通过“处理错误数值+记录log”的方式也可以达到我们的目标(事实上确实如此,在php3,php4的时候,已经出现了很多成功且足够复杂的系统,他们甚至考虑到所有的情况,因此不需要记录任何log)。但技术总要向前发展的,更何况,决大多数的开发人员并不具备牛人的严谨到滴水不漏的思维,所以我们还是不得不认真思考“如何处理程序错误”的问题。
上面的“错误处理+记录log”的方式,存在如下弊端:
1 如果错误情况太多,那相应的错误处理代码需要增加很多,这非常损害程序的可读性。你的程序看起来是“断断续续的”。
2 如果程序的逻辑很复杂(比如程序的函数调用非常复杂,如在 getResult2()函数 中调用 getResult() 的情况,甚至更复杂的多级嵌套的情况),那错误数值的传递处理会让你疲于奔命。因为为了确保错误能够得到有效的处理,你必须保证: 以无损耗的方式传递错误数值。
所以,改变这种原始的错误处理方式吧。引入异常处理机制,你会发现可喜的变化:
1 代码可读性大大增强。开发程序时逻辑思维变得很连贯,在“可疑的”地方,你只要抛出个异常就可以了。至于怎么处理,完全可以等到后面再去补充。当然,对于程序的读者,也不会觉得有被打断的感觉。
2 再也不需要考虑“错误数值如何无损耗的进行传递”这种费力又不怎么讨好的问题了。因为异常向上传递的特性,你的函数嵌套个2层,3层,再多层都没有问题。你只需要在外层有捕获异常的操作就可以了。
3 异常可以自由的定制,你可以按照功能对异常进行分类,更好的管理各种程序错误。同时对于你也可以更灵活的定制异常的处理方式。比如,在异常类里面实现记录log的功能等。
当然,是否使用异常要根据需求而定。php的一大特性就是部署快,如果是很小的项目,逻辑很简单,那使用一般的错误数值处理方式也许能够更快的部署。
PHP 相关文章推荐
玩转虚拟域名◎+ .
Oct 09 PHP
用PHP和ACCESS写聊天室(一)
Oct 09 PHP
从C/C++迁移到PHP——判断字符类型的函数
Oct 09 PHP
PHP读取目录下所有文件的代码
Jan 07 PHP
PHP爆绝对路径方法收集整理
Sep 17 PHP
通过curl模拟post和get方式提交的表单类
Apr 23 PHP
php版淘宝网查询商品接口代码示例
Jun 17 PHP
百度工程师讲PHP函数的实现原理及性能分析(三)
May 13 PHP
PHP的Socket网络编程入门指引
Aug 11 PHP
CodeIgniter视图使用注意事项
Jan 20 PHP
PHP registerXPathNamespace()函数讲解
Feb 03 PHP
TP3.2.3框架文件上传操作实例详解
Jan 23 PHP
phpmyadmin 访问被拒绝的真实原因
Jun 15 #PHP
两个强悍的php 图像处理类1
Jun 15 #PHP
PHP写MySQL数据 实现代码
Jun 15 #PHP
php ignore_user_abort与register_shutdown_function 使用方法
Jun 14 #PHP
纯真IP数据库的应用 IP地址转化成十进制
Jun 14 #PHP
PHP 定界符 使用技巧
Jun 14 #PHP
php 变量定义方法
Jun 14 #PHP
You might like
常用的php对象类型判断
2008/08/27 PHP
php实现简单洗牌算法
2013/06/18 PHP
PHP将XML转数组过程详解
2013/11/13 PHP
php 截取中英文混合字符串的方法
2018/05/31 PHP
js的写法基础分析
2011/01/17 Javascript
javascript 使用 NodeList需要注意的问题
2013/03/04 Javascript
css+js实现部分区域高亮可编辑遮罩层
2014/03/04 Javascript
JS实现的仿淘宝交易倒计时效果
2015/11/27 Javascript
深入学习jQuery Validate表单验证
2016/01/18 Javascript
js的各种排序算法实现(总结)
2016/07/23 Javascript
JQuery手速测试小游戏实现思路详解
2016/09/20 Javascript
详解AngularJS验证、过滤器、指令
2017/01/04 Javascript
js实现3D图片展示效果
2017/03/09 Javascript
nodejs实现邮件发送服务实例分享
2017/03/29 NodeJs
vue2中的keep-alive使用总结及注意事项
2017/12/21 Javascript
vue实现选项卡及选项卡切换效果
2018/04/24 Javascript
vue使用map代替Aarry数组循环遍历的方法
2020/04/30 Javascript
nuxt引入组件和公共样式的操作
2020/11/05 Javascript
[03:41]DOTA2上海特锦赛小组赛第三日recap精彩回顾
2016/02/28 DOTA
python为tornado添加recaptcha验证码功能
2014/02/26 Python
Python脚本修改阿里云的访问控制列表的方法
2019/03/08 Python
Python3中函数参数传递方式实例详解
2019/05/05 Python
python实现两个经纬度点之间的距离和方位角的方法
2019/07/05 Python
详解Python高阶函数
2020/08/15 Python
Kate Spade美国官网:纽约新兴时尚品牌,以包包闻名于世
2017/11/09 全球购物
NBA欧洲商店(英国):NBA Europe Store UK
2018/07/27 全球购物
迷你西餐厅创业计划书范文
2013/12/31 职场文书
优秀幼教自荐信
2014/02/03 职场文书
《特殊的葬礼》教学反思
2014/04/27 职场文书
金秋助学感谢信
2015/01/21 职场文书
Jupyter notebook 更改文件打开的默认路径操作
2021/05/21 Python
python 办公自动化——基于pyqt5和openpyxl统计符合要求的名单
2021/05/25 Python
十大动画制作软件,Adobe产品上榜两款,第一是行业标准软件
2022/03/18 杂记
Pandas 数据编码的十种方法
2022/04/20 Python
MySQL 原理优化之Group By的优化技巧
2022/08/14 MySQL
table设置超出部分隐藏,鼠标移上去显示全部内容的方法
2022/12/24 HTML / CSS