子程序应该不因传入错误数据而被破坏, 哪怕是由其余子程序产生的错误数据;换一种说法是, 程序员应该认可程序都是有问题的都须要被修改。程序员
软件开发领域“垃圾进,垃圾出”的原则已通过时,应该作到: 垃圾进,什么都不出;垃圾进,出错误提示;不准垃圾进。作法以下:编程
- 检查全部来源于外部的值
在程序开发和使用期间,用于程序自检的代码即为断言; 使用断言能够在程序出现问题时让程序员更快速的根据断言给出的信息排查问题和缘由。
断言一般含有两个参数:一个描述假设为真时的状况的布尔表达式,一个断言为假时须要显示的信息。函数创建本身的断言机制
能够使用的技术:返回中立值;换用下一个正确数据(如读取数据);返回与前次相同的数据(如图像显示处理);换用最接近的合法值(超过预设范围的值);把警告信息记录到日志文件中;返回一个错误码;调用错误处理子程序或对象;当错误发生时显示出错信息;用最稳当的方式在局部处理错误;关闭程序。工具
两者在某种意义上是相斥的spa
把代码中的错误和异常事件传递给调用方代码的一种特殊手段。debug
审慎明智的使用异常:设计
隔栏,一种代码的容损策略,如经常使用的: 在输入数据时将其转化为恰当的类型。版本控制
不要自动地把产品版的限制强加于开发版 之上
在开发阶段让异常尽可能显现出来,而在产品真正运行时可以自我修复调试
- 使用版本控制工具
- 保留那些检查重要错误的代码
用防护的姿态适当的因地制宜的使用防护式代码日志