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生成静态页
Nov 25 PHP
PHP中函数内引用全局变量的方法
Oct 20 PHP
PHP PDO函数库详解
Apr 27 PHP
php插入中文到sqlserver 2008里出现乱码的解决办法分享
Jul 19 PHP
两级联动select刷新后其值保持不变的实现方法
Jan 27 PHP
PHP开发注意事项总结
Feb 04 PHP
php实现RSA加密类实例
Mar 26 PHP
PHP数组函数array_multisort()用法实例分析
Apr 02 PHP
Thinkphp自定义代码生成工具及用法说明(附下载地址)
May 27 PHP
php进行md5加密简单实例方法
Sep 19 PHP
PHP7移除的扩展和SAPI
Mar 09 PHP
Laravel的加密解密与哈希实例讲解
Mar 24 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
ThinkPHP登录功能的实现方法
2014/08/20 PHP
Joomla使用Apache重写模式的方法
2016/05/04 PHP
php版阿里大于(阿里大鱼)短信发送实例详解
2016/11/30 PHP
php微信开发之音乐回复功能
2018/06/14 PHP
php获取微信基础接口凭证Access_token
2018/08/23 PHP
js 固定悬浮效果实现思路代码
2013/08/02 Javascript
浅谈javascript 函数内部属性
2015/01/21 Javascript
Express实现前端后端通信上传图片之存储数据库(mysql)傻瓜式教程(一)
2015/12/10 Javascript
AngularJS ionic手势事件的使用总结
2017/08/09 Javascript
使用clipboard.js实现复制功能的示例代码
2017/10/16 Javascript
Vuex提升学习篇
2018/01/11 Javascript
Javascript 之封装(Package)
2018/09/14 Javascript
Vue中用props给data赋初始值遇到的问题解决
2018/11/27 Javascript
详解Vue+Element的动态表单,动态表格(后端发送配置,前端动态生成)
2019/04/20 Javascript
基于JS实现操作成功之后自动跳转页面
2020/09/25 Javascript
Python中的高级数据结构详解
2015/03/27 Python
简单了解Python下用于监视文件系统的pyinotify包
2015/11/13 Python
详解如何用OpenCV + Python 实现人脸识别
2017/10/20 Python
python编程之requests在网络请求中添加cookies参数方法详解
2017/10/25 Python
Python实现爬取亚马逊数据并打印出Excel文件操作示例
2019/05/16 Python
python操作日志的封装方法(两种方法)
2019/05/23 Python
python zip,lambda,map函数代码实例
2020/04/04 Python
python如何随机生成高强度密码
2020/08/19 Python
python PyAUtoGUI库实现自动化控制鼠标键盘
2020/09/09 Python
如何快速一次性卸载所有python包(第三方库)呢
2020/10/20 Python
python基于pygame实现飞机大作战小游戏
2020/11/19 Python
学习雷锋寄语大全
2014/04/11 职场文书
天地会口号
2014/06/17 职场文书
大三学生学年自我鉴定
2014/09/12 职场文书
实习单位鉴定意见
2015/06/04 职场文书
2016年青少年禁毒宣传教育活动总结(学校)
2016/04/05 职场文书
opencv读取视频并保存图像的方法
2021/06/04 Python
七个非常实用的Python工具包总结
2021/06/15 Python
一篇文章弄懂Python关键字、标识符和变量
2021/07/15 Python
python字典的元素访问实例详解
2021/07/21 Python
MySQL中的 inner join 和 left join的区别解析(小结果集驱动大结果集)
2023/05/08 MySQL