单元测试的效益

上一篇 / 下一篇  2012-12-03 16:16:33

单元测试是针对代码单元,特别是算法密集的代码单元的独立测试,可以完整覆盖代码单元的功能逻辑,保证代码质量、降低成本、提高生产率、缩短开发周期、赢得市场先机、提升产品竞争力。 

    单元测试分为静态和动态,静态方法只能发现小部分错误,例如,加法函数int add(int a, int b){return a-b;};,加号写成了减号,这种最简单代码中的最简单错误,任何静态工具都无法发现,而动态方法只需输入两个1,自动判断输出是否等于2,马上就能发现错误。静态方法能发现的错误,如除零错、数组越界、条件语句中==写成=,都会表现为异常或功能错误,动态方法当然也能发现,因此,动态方法是单元测试的根本方法。 

    无处不在的80-20规则,在软件开发中同样存在,例如,80%的错误存在于20%的代码中,80%的项目时间消耗在20%的代码上,当然这只是粗略的估计。“20%代码”就是逻辑复杂的代码,也就是算法密集的代码。一个算法密集的函数,要对输入仔细分类,一个判定就是一次分类,嵌套的判定更使分类次数翻番,遗漏一个分类,或一个分类处理不正确,就会造成错误。只有完整覆盖代码单元的所有输入等价类,才能保证发现这些错误,这在调试和系统测试中是难于做到的。算法密集的代码包含了项目中的大多数错误,即使只对这部分代码实施单元测试,也能产生理想的效益。 

    除了保证代码质量,单元测试还具有排错成本最低、易于自动回归、缩短后续测试周期、提高编程效率等显著效益。

TAG:

 

评分:0

我来说两句

日历

« 2024-05-24  
   1234
567891011
12131415161718
19202122232425
262728293031 

数据统计

  • 访问量: 6404
  • 日志数: 10
  • 建立时间: 2012-09-25
  • 更新时间: 2012-12-07

RSS订阅

Open Toolbar