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 相关文章推荐
BBS(php & mysql)完整版(五)
Oct 09 PHP
PHP+DBM的同学录程序(3)
Oct 09 PHP
php 字符串替换的方法
Jan 10 PHP
表格展示无限级分类(PHP版)
Aug 21 PHP
php中使用getimagesize获取图片、flash等文件的尺寸信息实例
Apr 29 PHP
php绘制一条弧线的方法
Jan 24 PHP
隐性调用php程序的方法
Jun 13 PHP
培养自己的php编码规范
Sep 28 PHP
PHP Header用于页面跳转时的几个注意事项
Oct 21 PHP
Zend Framework动作控制器用法示例
Dec 09 PHP
PHP支付宝当面付2.0代码
Dec 21 PHP
thinkphp整合系列之极验滑动验证码geetest功能
Jun 18 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
一个程序下载的管理程序(一)
2006/10/09 PHP
php的hash算法介绍
2014/02/13 PHP
php使用PDO方法详解
2014/12/27 PHP
Windows下PHP开发环境搭建教程(Apache+PHP+MySQL)
2016/06/13 PHP
对php 判断http还是https,以及获得当前url的方法详解
2019/01/15 PHP
JScript中的"this"关键字使用方式补充材料
2007/03/08 Javascript
JSON 学习之完全手册 图文
2007/05/29 Javascript
js 事件小结 表格区别
2007/08/13 Javascript
javascript常用对话框小集
2013/09/13 Javascript
js 判断文件类型并控制表单提交示例代码
2013/11/14 Javascript
jquery datepicker参数介绍和示例
2014/04/15 Javascript
jQuery实现为图片添加镜头放大效果的方法
2015/06/25 Javascript
jQuery焦点图切换特效代码分享
2015/09/15 Javascript
基于jQuery插件实现点击小图显示大图效果
2016/05/11 Javascript
详解微信小程序 页面跳转 传递参数
2016/12/08 Javascript
jQuery插件MovingBoxes实现左右滑动中间放大图片效果
2017/02/28 Javascript
javascript checkbox/radio onchange不能兼容ie8处理办法
2017/06/13 Javascript
Vue组件开发之LeanCloud带图形校验码的短信发送功能
2017/11/07 Javascript
Javascript 实现 Excel 导入生成图表功能
2018/10/22 Javascript
koa router 多文件引入的方法示例
2019/05/22 Javascript
vue中使用vue-pdf的方法详解
2020/09/05 Javascript
python使用Berkeley DB数据库实例
2014/09/26 Python
Python爬虫实现抓取京东店铺信息及下载图片功能示例
2018/08/07 Python
Python 实现子类获取父类的类成员方法
2019/01/11 Python
用Python调用win命令行提高工作效率的实例
2019/08/14 Python
Pyecharts绘制全球流向图的示例代码
2020/01/08 Python
tensorflow2.0教程之Keras快速入门
2021/02/20 Python
CSS中的字体大小设置属性总结
2016/05/24 HTML / CSS
详解如何在css中引入自定义字体(font-face)
2018/05/17 HTML / CSS
Paper Cape官网:美国婴儿和儿童服装品牌
2019/11/02 全球购物
老师对学生的评语
2014/04/18 职场文书
企业党建工作汇报材料
2014/08/19 职场文书
国际残疾人日广播稿范文
2014/10/09 职场文书
幼儿园教师读书笔记
2015/06/29 职场文书
python opencv人脸识别考勤系统的完整源码
2021/04/26 Python
golang 生成对应的数据表struct定义操作
2021/04/28 Golang