热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

软件调试修炼之道之——特殊案例

特殊案例之一就是修补已经发布的软件,诊断这种缺陷与其他缺陷并没有什么不同,但修复的目标通常是要修复错误的根源,而对已经发布的软件要进行修补时,他只是在最大程度降低风险。如果缺陷出现在用户已经使用的

特殊案例之一就是修补已经发布的软件,诊断这种缺陷与其他缺陷并没有什么不同,但修复的目标通常是要修复错误的根源,而对已经发布的软件要进行修补时,他只是在最大程度降低风险。

如果缺陷出现在用户已经使用的软件中,那么需要考虑向后兼容的问题。首先需要确定正在进行的修复是否可能引起兼容问题,此时,我们能做的就是对整体了解的基础上思考,将确定兼容性问题加入到缺陷修复的检查列表中,一旦确定有兼容性问题,该如何解决呢

1. 提供迁移的方法:给用户提供一些方法来修改其现有数据,代码等东西,以适应新的规则。

2. 实现一个兼容模式:比如office word 2010打开word 2003版本显示如下:

这不是一个能被轻易采用的方法,因为它的成本非常高。从用户的角度来看,兼容模式让人困惑,他们必须知道软件支持两种不同的行为,它们的不同之处是什么,什么时候用哪种模式,只有付出的成本合理时才会用这种模式。

3. 提供预警:只有当你能长时间延长修复以使你的用户能够迁移,并且知道用户是否真的迁移的情况下才有效。

4. 不修复缺陷:当然,这不是一个好的解决方案,只是,极少数情况下,它是一个务实的选择。

并发软件是难以重现、难以诊断以及难以修复的主要问题来源。这些软件的缺陷具有很大的不确定性,它们之间存在微妙并且难以理解的相互作用,并且受很多不明原因的失效模式影响。

可以在并发软件中添加很多东西帮你调试,两个关键的要素就是简单和控制

简单是任何软件设计的关键要素之一,但是它在处理并发问题时尤其重要。保持独立线程的直接相互作用,尽可能将它们限制在一些小的代码区内等。

一个简单的设计不仅可以使你的软件更容易理解,并且从一开始就会减少缺陷的产生,而且更容易控制。

当你要修复并发软件中产生的缺陷的时候,要记住一个关键的要素——让它们尽可能少发生不是可取的修复办法

修复并发缺陷时,要避免使用sleep()方法,虽然它在强迫缺陷可靠重现的时候是一种极其有用的手段。

海森堡缺陷,一个当你开始寻找的时候就会“消失”的缺陷,也被称为观察者效应。

海森堡缺陷依赖于软件的某些不确定因素,这本身可以成为一个有用的线索。之前我们说过,导致不确定性因素的原因是非常有限的,所以意味着这个缺陷一定会被这些原因中的一个所影响。你应该进行的最快最容易的尝试是从一个收集信息的方法转换到另一个方法,如果不行,则要找到某种方法来收集你所需要的信息,这种方法对软件的影响极小,保证不会改变它的行为,而日志记录是改变时序的一个主要原因。你可以利用对不确定性区域的理解,来避免影响这些区域。

如何确定海森堡缺陷被修复了呢?唯一的办法就是要比平时更仔细,确保你真正的了解潜藏的根本原因。

性能缺陷:如同任何种类的缺陷,解决性能问题的关键是确定问题产生的根本原因。十之八九,这意味着你将去寻找瓶颈——代码的某个特定区限制了整体性能,按照从运行的软件中收集的数据运行,这是唯一确定的解决方法。因此,主要关注点是保证生成的性能分析文档能够准确反映软件的真实行为。

准确的性能分析:你要分析的构建应该尽可能接近产品版本,运行的环境要尽可能与软件的最终目标运行环境相同,使用具有代表性的数据运行软件。

如果没有瓶颈呢?如果没有性能瓶颈,但是软件运行很慢,那么主要的原因可能有:资源耗尽(是否存在内存或资源泄露)、垃圾收集(软件是否分配很多短生命周期的对象让GC频繁运行)、缓存(遇到大量缓存丢失?)。

嵌入式软件:调试嵌入式软件的棘手并不在于它的错综复杂,而是因为它的运行环境,此时,你需要一些调试工具帮助你。

第三方软件缺陷:第三方的代码只是代码,而且,如同任何代码,它也包含缺陷,所以,很可能你要追踪的问题不是你自己造成的。但是,不要轻易埋怨别人。带着怀疑的眼光对待自己的代码,首先假设你的代码是有缺陷的。当你用尽了方法证明自己的代码正确,再去埋怨三方的代码。如何处理三方代码中的缺陷呢?提交报告等待三方负责人修复缺陷,当然,你可以尝试找到问题的解决方法,并在缺陷报告上详细说明,可能的话,与三方负责人进行沟通,而最好的解决办法通常是在短期内搁置问题。

一种非常重要的第三方代码是开源代码:只要给予足够的关注,所有的缺陷都是浅显的,但是开源并不意味着传统调试的结束。开源的本质意味着你不能以中心化的方式构建软件。开源社区可以提供很大的帮助,在这里,可以得到完全免费的高质量软件,而高质量的技术支持也是免费的,但是,有效的寻求帮助是一门艺术

首先,做你应该做的,检查文档,经常提出问题,搜索邮件列表和博客条目,看看是否其他人也遇到过同样的问题。

尽可能多的给出信息。

记住:帮助你的人是自愿的。

如果你修复了缺陷,之后可将修复程序提交回中央进行处理。


推荐阅读
  • 本文探讨了如何在日常工作中通过优化效率和深入研究核心技术,将技术和知识转化为实际收益。文章结合个人经验,分享了提高工作效率、掌握高价值技能以及选择合适工作环境的方法,帮助读者更好地实现技术变现。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 数据库内核开发入门 | 搭建研发环境的初步指南
    本课程将带你从零开始,逐步掌握数据库内核开发的基础知识和实践技能,重点介绍如何搭建OceanBase的开发环境。 ... [详细]
  • 本文深入探讨了如何通过调整InnoDB的关键配置参数来优化MySQL的随机IO性能,涵盖了缓存、日志文件、预读机制等多个方面,帮助读者全面提升数据库系统的性能。 ... [详细]
  • 本文详细介绍了 MySQL 的查询处理流程,包括从客户端连接到服务器、查询缓存检查、语句解析、查询优化及执行等步骤。同时,深入探讨了 MySQL 中的乐观锁机制及其在并发控制中的应用。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 百度服务再次遭遇技术问题,疑似DNS解析故障
    近日晚间,百度多项在线服务出现加载异常,包括移动端搜索在内的多个功能受到影响。初步迹象表明,问题可能与DNS服务器解析有关。 ... [详细]
  • 本文详细介绍了MicroATX(也称Mini ATX)和MATX主板规格,探讨了它们的结构特点、应用场景及对电脑系统成本和性能的影响。同时,文章还涵盖了相关操作系统的实用技巧,如蓝牙设备图标删除、磁盘管理等。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 本文深入探讨了 Redis 的两种持久化方式——RDB 快照和 AOF 日志。详细介绍了它们的工作原理、配置方法以及各自的优缺点,帮助读者根据具体需求选择合适的持久化方案。 ... [详细]
  • FinOps 与 Serverless 的结合:破解云成本难题
    本文探讨了如何通过 FinOps 实践优化 Serverless 应用的成本管理,提出了首个 Serverless 函数总成本估计模型,并分享了多种有效的成本优化策略。 ... [详细]
  • 本文详细介绍了 RosPack 类的功能和用法,探讨了其在 ROS 系统中的重要作用。RosPack 类提供了类似于终端命令 rospack 的功能,能够方便地查询和管理 ROS 包的相关信息。 ... [详细]
author-avatar
木目心磊_559
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有