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 相关文章推荐
PHP:风雨欲来 路在何方?
Oct 09 PHP
PHP mkdir()定义和用法
Jan 14 PHP
调整PHP的性能
Oct 30 PHP
php+js iframe实现上传头像界面无跳转
Apr 29 PHP
使用phpstorm和xdebug实现远程调试的方法
Dec 29 PHP
Yii的Srbac插件用法详解
Jul 14 PHP
PHP Oauth授权和本地加密实现方法
Aug 12 PHP
PHP实现截取中文字符串不出现?号的解决方法
Dec 29 PHP
PHP基于ORM方式操作MySQL数据库实例
Jun 21 PHP
PHP 返回数组后处理方法(开户成功后弹窗提示)
Jul 03 PHP
php处理抢购类功能的高并发请求
Feb 08 PHP
Yii2.0框架模型添加/修改/删除数据操作示例
Jul 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
php+xml编程之SimpleXML的应用实例
2015/01/24 PHP
实现PHP框架系列文章(6)mysql数据库方法
2016/03/04 PHP
PHP的PDO常用类库实例分析
2016/04/07 PHP
PHP获取表单数据与HTML嵌入PHP脚本的实现
2017/02/09 PHP
JQuery 学习笔记 选择器之二
2009/07/23 Javascript
js 巧妙去除数组中的重复项
2010/01/25 Javascript
Javascript学习笔记-详解in运算符
2011/09/13 Javascript
用Jquery重写windows.alert方法实现思路
2013/04/03 Javascript
jQuery中outerHeight()方法用法实例
2015/01/19 Javascript
Struts2+jquery.form.js实现图片与文件上传的方法
2016/05/05 Javascript
jquery 正整数数字校验正则表达式
2017/01/10 Javascript
jQuery实现表格奇偶行显示不同背景色 就这么简单
2017/03/13 Javascript
捕获未处理的Promise错误方法
2017/10/13 Javascript
NodeJS实现不可逆加密与密码密文保存的方法
2018/03/16 NodeJs
Node.js log4js日志管理详解
2018/07/31 Javascript
详解Vue.js在页面加载时执行某个方法
2018/11/20 Javascript
express 项目分层实践详解
2018/12/10 Javascript
微信小程序制作表格的方法
2019/02/14 Javascript
vue组件间通信六种方式(总结篇)
2019/05/15 Javascript
微信小程序之滑动页面隐藏和显示组件功能的实现代码
2020/06/19 Javascript
[03:03]DOTA2 2017国际邀请赛开幕战队入场仪式
2017/08/09 DOTA
[05:09]DOTA2-DPC中国联赛2月22日Recap集锦
2021/03/11 DOTA
python爬虫入门教程--HTML文本的解析库BeautifulSoup(四)
2017/05/25 Python
使用Django Form解决表单数据无法动态刷新的两种方法
2017/07/14 Python
详解Python下ftp上传文件linux服务器
2018/06/21 Python
解决Pycharm运行时找不到文件的问题
2018/10/29 Python
Django框架验证码用法实例分析
2019/05/10 Python
用python wxpy管理微信公众号并利用微信获取自己的开源数据
2019/07/30 Python
Python 利用高德地图api实现经纬度与地址的批量转换
2019/08/14 Python
HTML5中form如何关闭自动完成功能的方法
2018/07/02 HTML / CSS
搬家公司的创业计划书
2014/01/01 职场文书
收银员岗位职责
2014/02/07 职场文书
同学聚会通知书
2015/04/20 职场文书
无保留意见审计报告
2015/06/05 职场文书
多人股份制合作协议书
2016/03/19 职场文书
Python中的嵌套循环详情
2022/03/23 Python