举一个简单的例子:如果一个人很健壮,那么他在遇到一些小毛病的时候,比如感冒,能够很快恢复,而不至于遇到感冒就倒掉了
对比过来,就是如果一个程序很健壮,那么他在遇到感冒的时候(比如,想要打开的文件不存在),也能够很快恢复(处理异常情况,输出错误信息等),然后继续运行下去,而不至于一遇到感冒就die了。
简单的说,健壮性的代码就是遇到问题不容易崩溃的代码。
健壮性的思想:
(1)正常运行的代码.首要追求高效性
这个"高效性"如果从逻辑的角度来解释,那么一方面是"高效"地对正确的数据执行正确的算法(方法/策略),另一方面是"高效"地找出异常,然后丢给异常处理代码去处理.
(2)处理异常的代码.首要追求健壮性.
就是程序必须能从异常中自我恢复.由于代码多数时间跑的是"正常"逻辑,少数情况下才不得不处理"异常",所以"异常"处理的代码中,首要任务是健壮,跑不死,而高效性则是次要的.
这里谈一下我的认识:“正常运行的代码”和“异常处理的代码”类似于:
//或者使用try catch 方式
if (判断传入参数的类型是否匹配)
{
//"正常运行代码"
//匹配,走正常处理流程, 直接把返回值传给上层逻辑处理
}
else
{
//"异常处理代码"
//不匹配,走异常处理流程,重新扫描传入的数据,或者给出提示
}
健壮性的运用:
1、在做前台页面过程中,对于ASP.NET验证控件的使用、正则表达式的使用,要融入到我们的日常编程习惯当中。传到后台的错误(类似于到B层逻辑判断进行不下去)才发现的错误,在前台一定要保证根本不让这些参数传入到后台,扼杀在摇篮中。
2、合理布局函数返回值,保证函数返回值一致
之前很多时候写函数往往很随性,返回值类型可以能代表函数执行成功或者失败的Bool型,也会有代表实际结果的Str或者Int等类型。这样的函数在外部调用时痛苦非常,因为在函数调用后处理时,处理不当就会出现typeError,所以在函数编写前,要思考后本函数的作用,同时确定返回值类型,在函数的所有涉及到返回结果时,给予一致类型的返回值,方便外部调用。
3、必要情况下的Try…Catch…处理
Try…Catch…出来处理异常是各种语言都有的模式。但到底在何处使用却有讲究。在没有抛异常的语句使用try语句,会降低性能,带来代码冗余,而在需要处理的语句未加异常处理,则会带来运行崩溃的可能。所以,要深刻的了解代码的语句,是否存在抛异常的可能,对可能抛异常的语言要加以处理。(这方面的介绍在下一篇实战博客中会进行讲解)
4、清理代码,去掉冗余代码
很多时候,我们的代码都是迭代开发的。往往会罗列一些无用的函数,引入一些无用的类库。这些内容貌似无意义,但却是代码中的隐患。可能在后续的类库更新或者函数变更中爆炸。所以,代码要保持清理,对于无用的引用和定义,要加以清除。
引用自"杀死那个进程"的博客'代码健壮性-理论篇':https://blog.csdn.net/zzh920625/article/details/50761058