ImageVerifierCode 换一换
格式:PPT , 页数:24 ,大小:506KB ,
资源ID:7436812      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-7436812.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(8_9 调试.ppt)为本站会员(ysd1539)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

8_9 调试.ppt

1、8.9 调试,2 /75,调试是在测试发现错误之后排除错误的过程。 调试(也称为纠错),3 /75,关于调试主要研究如下内容:,8.9.1 调试过程 8.9.2 调试技术 简单调试法 归纳法 演绎法 回溯法,4 /75,8.9.1 调试过程,调试的目的 调试过程,5 /75,调试的目的,调试的目的,是为了确定错误的原因和位置,并进行纠错;,6 /75,调试的过程,调试不是测试,但是它总是发生在一个成功的测试之后。 如图7.8所示,成功的测试发现错误之后,通过调试过程试图找出产生症状的原因和位置,以便纠错。,7 /75,调试的过程,图7.8 调试过程,8 /75,调试的过程,调试过程总会有以下两

2、种结果之一:找到了问题的原因并把问题改正和排除掉了; 没找出问题的原因。在后一种情况下,调试人员可以猜想一个原因,并设计测试用例来验证这个假设,重复此过程直至找到原因并改正了错误。,9 /75,调试活动也很困难,具有挑战性,调试是软件开发过程中最艰巨的脑力劳动。调试工作如此困难,可能心理方面的原因多于技术方面的原因,但是,软件错误的下述特征也是相当重要的原因: 症状和产生症状的原因可能在程序中相距甚远,也就是说,症状可能出现在程序的一个部分,而实际的原因可能在与之相距很远的另一部分,紧耦合的程序结构更加剧了这种情况。 当改正了另一个错误之后,症状可能暂时消失了。 症状可能实际上并不是由错误引起

3、的(例如,舍入误差)。,10 /75,调试活动也很困难,具有挑战性,症状可能是由不易跟踪的人为错误引起的。 症状可能是由定时问题而不是由处理问题引起的。 可能很难重新产生完全一样的输入条件(例如,输入顺序不确定的实时应用系统)。 症状可能时有时无,这种情况在硬件和软件紧密地耦合在一起的嵌入式系统中特别常见。症状可能是由分布在许多任务中的原因引起的,这些任务运行在不同的处理机上。,11 /75,调试活动也很困难,具有挑战性,在调试过程中会遇到从恼人的小错误(例如,不正确的输出格式)到灾难性的大错误(例如,系统失效导致严重的经济损失)等各种不同的错误。 错误的后果越严重,查找错误原因的压力也越大。

4、通常,这种压力会导致软件开发人员在改正一个错误的同时引入两个甚至更多个错误。,12 /75,8.9.2 调试技术,简单的调试方法 回溯法 原因排除法 对分查找 归纳法(由多点、到定性或规律,再到定位) 演绎法(由一般经验或规律,推测排除,最后定位),13 /75,. 简单的调试方法,在源程序中设置“锚点”,给出输出; 运行部分程序;,14 /75,2. 回溯法,回溯是一种相当常用的调试方法,当调试小程序时这种方法是有效的。 具体做法是,从发现症状的地方开始,人工沿程序的控制流往回追踪分析源程序代码,直到找出错误原因为止。 但是,随着程序规模扩大,应该回溯的路径数目也变得越来越大,以至彻底回溯变

5、成完全不可能了。,15 /75,原因排除法,对分查找法 归纳法 演绎法 以上都属于原因排除法。,16 /75,(1)对分查找法,基本思路是,如果已经知道程序内若干个关键点的正确值,则可以用赋值语句或输入语句在程序中点附近“注入”这些变量的正确值,然后运行程序并检查所得到的输出。如果输出结果是正确的,则错误原因在程序的前半部分;反之,错误原因在程序的后半部分。 对错误原因所在的那部分再重复使用这个方法,直到把出错范围缩小到容易诊断的程度为止。,17 /75,(2)归纳法,是从个别现象推断出一般性结论的思维方法。 从具体的出错点,对出错数据进行分析,归纳出可能的错误原因。 然后导出对错误原因的一个

6、或多个假设,并利用已有的数据来证明或排除这些假设。 当然,如果已有的数据尚不足以证明或排除这些假设,则需设计并执行一些附加测试用例,以获得更多的数据。,18 /75,(3)演绎法,一般原理或前提出发,经过排除和精化的过程推导出结论。 首先设想出所有可能的出错原因,然后试图用测试来排除每一个假设的原因。 如果测试表明某个假设的原因可能是真的原因,则对数据进行细化以准确定位错误。,19 /75,上述3种调试途径都可以使用调试工具辅助完成,但是工具并不能代替对全部设计文档和源程序的仔细分析与评估。,20 /75,小结,如果用遍了各种调试方法和调试工具却仍然找不出错误原因,则需要换一种思维定式,应该向

7、同行求助。把遇到的问题向同行陈述并一起分析讨论,往往能开阔思路,较快找出错误原因。 一旦找到错误就必须改正它,但是,改正一个错误可能引入更多的其他错误,以至“得不偿失”。因此,在动手改正错误之前,软件工程师应该仔细考虑下述3个问题:,21 /75,(1) 是否同样的错误也在程序其他地方存在? 在许多情况下,一个程序错误是由错误的逻辑思维模式造成的,而这种逻辑思维模式也可能用在别的地方。 仔细分析这种逻辑模式,有可能发现其他错误。,22 /75,(2) 将要进行的修改可能会引入的“下一个错误”是什么? 在改正错误之前应该仔细研究源程序(最好也研究设计文档),以评估逻辑和数据结构的耦合程度。 如果所要做的修改位于程序的高耦合段中,则修改时必须特别小心谨慎。,23 /75,(3) 为防止今后出现类似的错误,应该做什么? 如果不仅修改了软件产品还改进了开发软件产品的软件过程,则不仅排除了现有程序中的错误,还避免了今后在程序中可能出现的错误。,24 /75,完,

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报