zoukankan      html  css  js  c++  java
  • 软件调试修炼之道之——诊断(下)

    在诊断期间有无数的方法会误导人,因此这里我们来一起看看所谓的陷阱

    你做的修改是正确的吗?如果你做的修改似乎没有任何效果,那么你并没有改到点子上,因此要在潜意识里时刻提高警惕。

    验证假设:了解你正在做什么样的假设,对它们进行严格的检验。

    多重原因:面临多种原因的最常见信号是一种你处于模糊状态的感觉——发生了一些似乎没有明显解释的怪事情,最富有成效的解决多原因缺陷的办法是对问题进行隔离,并找到一个方法来重现缺陷,重现的缺陷产生的原因只依赖于多个原因中的一个,而不依赖于其他原因。另一个方法是开始先找寻同一区域内其他较明显的缺陷,处理这些缺陷有时可以扫清障碍,让你理解得更透彻,使初始问题更加凸显。

    流沙:模糊感觉产生的另一个原因是一个不断变化的基础系统。面对一个不断变化的基础系统,停下手头工作并弄清是什么在变化,为什么在变化。

    调试是很艰苦的,有时简直苦不堪言,当你看不清前进的方向的时候可以试试以下的技巧:

    旁观调试法:最有效的一个扫除障碍的策略就是向其他人求助,解释问题会帮助你理清思路。

    角色扮演:角色扮演在解释和探讨问题时十分有用,特别在涉及那些互相独立的系统之间相互作用的问题时。

    换换脑筋:让潜意识帮助自己。

    做些改变:有时候,完全陷入困境之中,做些改变是十分必要的,任何改变都可以,也许它不会告诉你任何东西,但有时它会让你感到惊奇,让你惊奇的事总会教给你一些东西。

    福尔摩斯原则:当你排除了一切不可能后,无论剩下什么,无论它多么不可思议,也一定是真相。

    坚持:虽然有时候看起来不是这样,但实际上任何一个缺陷都是可以被诊断的。只要有足够的时间,付出足够的精力和决心,一定会解决的。

    无论如何,当你诊断出了问题的所在,在进行修复之前,务必要验证诊断,可以向其他人解释你的诊断,也可以检查源代码的原始副本,尝试和他人讨论并假设自己是错误的,这样可以让你信任自己所做的诊断,也就可以开始着手进行修复了。

    本章至此告一段落,一旦确诊,接下来的我们就该聊聊修复的问题了~

  • 相关阅读:
    Clipper库中文文档详解
    uboot makefile构建分析
    nvidia tk1使用记录--基本环境搭建
    学习
    es6 es7新语法
    react dva发送请求详解(转)
    antDesign表单getFieldDecorator
    react dav
    js实现截取a标签的href属性和内容
    react学习
  • 原文地址:https://www.cnblogs.com/Ribbon/p/2920906.html
Copyright © 2011-2022 走看看