谈防御式编程---发表于公司黑板报的第一篇文章
2015-06-11 07:53
211 查看
最近一段时间,时常会出现BCC进程在业务过程中挂掉之后重启,或者干脆挂掉不重启的问题。每次问题定位之后,总是最简单的失误,绝大多数是指针没有进行空保护就使用,也有类声明了构造函数而未实现引起Fail的问题。被问题牵着走总是苦恼的,定位的过程也常常艰辛,有Core文件的帮助的话一般能比较快速的定位,没有Core文件时定位问题过程相当煎熬。
与其艰难定位,不如在编程时考虑代码的防御性。举例来说,对于某个消息的处理,字符串都是指针形式,凡是用到指针就进行保护,而不是认定消息中的某某字段是必填的。这里举一些常见需要我们去“防御”的内容:
1. 指针:使用之前进行空判断。
2. 数组:每次获取数组内容,都考虑下标是否越界?进行必要的保护
3. 除法运算:除数是否为0?
4. 循环:循环的上限是否超出了变量范围?
5. 加减法: 是否存在可能的加翻?减翻?
当然需要防御的点还有很多,不能一一列举,但是防御式编程的核心思想是:无论何时何处,都应该对代码进行完整的保护,而不是假设输入都是正常的。以指针为例来说:即使考虑所有情况下指针都不可能为空,还是进行空指针的判断;函数A调用函数B,即使在函数A中进行了空指针保护,函数B中依然进行保护,也许看着有点多余,但这正是代码的防御性所在,谁能保护函数B将来不被另一个函数C调用,而C中没有进行任何指针的保护呢?
更多关于防御式编程的更多内容可参考《code complete》书中的相关内容。
希望我们都能有代码防御性的意识,一方面是降低服务Fail、出现事故的机率,另一方面把我们自己从问题定位中解放出来。
与其艰难定位,不如在编程时考虑代码的防御性。举例来说,对于某个消息的处理,字符串都是指针形式,凡是用到指针就进行保护,而不是认定消息中的某某字段是必填的。这里举一些常见需要我们去“防御”的内容:
1. 指针:使用之前进行空判断。
2. 数组:每次获取数组内容,都考虑下标是否越界?进行必要的保护
3. 除法运算:除数是否为0?
4. 循环:循环的上限是否超出了变量范围?
5. 加减法: 是否存在可能的加翻?减翻?
当然需要防御的点还有很多,不能一一列举,但是防御式编程的核心思想是:无论何时何处,都应该对代码进行完整的保护,而不是假设输入都是正常的。以指针为例来说:即使考虑所有情况下指针都不可能为空,还是进行空指针的判断;函数A调用函数B,即使在函数A中进行了空指针保护,函数B中依然进行保护,也许看着有点多余,但这正是代码的防御性所在,谁能保护函数B将来不被另一个函数C调用,而C中没有进行任何指针的保护呢?
更多关于防御式编程的更多内容可参考《code complete》书中的相关内容。
希望我们都能有代码防御性的意识,一方面是降低服务Fail、出现事故的机率,另一方面把我们自己从问题定位中解放出来。
相关文章推荐
- eclipse中编写代码时如何自动提示变量名?
- springmvc:Failed to convert value of type
- QT积累
- 关于ruby on rails测试的一些笔记
- Algorithms
- Java基本数据类型及其封装类
- 游戏服务端中使用Servlet和Java注解的一个好设计
- Java Iterator学习小结
- Qt4学习(2)——布局使用(制作登记界面)
- Spring AOP的一个简单例子
- Spring MVC @ResponseBody返回中文字符串乱码问题
- Spring简介
- php session跨页面传值
- python 模拟浏览器
- laravel homestead vagrant box安装使用,问题,及相关命令
- JSON 字符串 与 java 对象的转换
- Python 网页爬虫 & 文本处理 & 科学计算 & 机器学习 & 数据挖掘兵器谱
- Python 网页爬虫 & 文本处理 & 科学计算 & 机器学习 & 数据挖掘兵器谱
- 图论算法 有图有代码 万字总结 向前辈致敬
- 图论算法 有图有代码 万字总结 向前辈致敬