- 1、本文档共35页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
漂亮的测试
—— 《代码之美》第七章
——By Alberto Savoia
——史际帆
作者简介:Alberto Savoia
Alberto Savoia is co-founder and CTO of Agitar Software.
Before Agitar, he was Senior Director of Engineering at Google;
prior to that he was the Director of Software Research at Sun
Microsystems Laboratories.
Alberto’s passion and main body of work and research is in the
area of software development technology—in particular, tools and
technology to help programmers test and verify their own code
during the design and development phase.
Alberto Savoia 是Agitar软件公司创始人之一
和CEO。在创建Agitar之前,它是Google的
高级工程主管;在这之前,他还是Sun
Microsystems实验室软件研究中心的主管。
其主要研究领域是软件开发技术——尤其是
那些帮助程序员在设计和开发阶段尽心测试
和代码验证的工具和技术。
何以谓“漂亮的代码”?
实现所要求的功能
优雅、简洁
“漂亮的测试”呢?
测试是对于代码正确与否的检验,当然也应该漂亮。而测试天
生带有组合性与试探性,单一测试的漂亮并不一定组合起来还漂亮。
例如:代码中的每一条if语句至少需要两个测试:一个测试条件表达
式为真,另一个测试其为假的情况。
而 if ( a || b || c ) 则理论上需要八个测试。再考虑到循环中的异常,
多个输入参数,对外部代码的依赖,不同的软硬件平台等,所需测
试的数量和类型将大大增加。
所以除最简单外,任何代码都需要一组测试而不是一个。其中每一个测
试专注于检查代码的一个特定方面。就像球队中不同球员有不同职责,负
责不同区域一样。
测试一般是逐步建立的,并逐步来验证所测试代码的正确与高效性。
测试的漂亮:
简单、迅速
揭示出代码的本质
找出逻辑错误,发现结构和设计上的问题,使代码更健壮,更
有可读性。
测试具有深度与广度
深入彻底、覆盖无遗,增强开发者信心。
讨论漂亮的测试,必先寻找足够生动有趣,常出bug而本身
简单漂亮的代码。
作者找到了Jon Bentley 《Programming Pearls》书中的二
分法查找算法。
二分查找 Bug: 如果low和high 的和大
Here is a Java implementation with the infamous bug:于
Integer.MAX_VALUE(Java
public static int buggyBinarySearch(int[] a, int target) { 中是231-1),计算将会溢出
int low = 0; 使之成为一个负数。
int high = a.length - 1; Jon Bentley 向学生们讲述此算法:
while (low = high) { 在一个包含t 的数组中,通过将范围中间的
int mid = (low + high) / 2; 元
您可能关注的文档
最近下载
- 肿瘤康复管理项目实施方案.docx VIP
- TB-T2075-2002《电气化铁道接触网零部件》.pdf VIP
- 高甘油三酯血症性急性胰腺炎诊治急诊专家共识2021解读.pptx
- 15J401 钢梯(建筑图集).docx
- 《精神分裂症治疗前后烟酸皮肤反应的变化及其与症状功能的关系》.docx
- 2023年厦门大学嘉庚学院软件工程专业《计算机组成原理》科目期末试卷B(有答案).docx VIP
- 2025年机动车检测站管理评审.doc VIP
- 中标麒麟高级服务器操作系统软件技术指标.pdf VIP
- 2022年厦门大学嘉庚学院软件工程专业《计算机组成原理》科目期末试卷B(有答案).docx VIP
- 2023中标麒麟桌面操作系统软件(龙芯版)V7.0-用户手册.docx VIP
文档评论(0)