advanced windows debug(windows高级调试)读后感

本文是关于《advanced windows debug》一书的读后感,主要讲述了使用Windbg进行调试的经验,包括栈破坏、堆破坏问题的解决,以及自定义扩展调试命令的编写。此外,对比了Windbg与Visual Studio的调试功能,强调了Windbg在查看句柄、内存堆和解决minidump问题上的优势。书中结合实例,提供了深入理解Windows底层调试知识的路径,对于提升Windows调试技能很有帮助。
摘要由CSDN通过智能技术生成

去年买了这本书一直没看,直到最近总算大致看完了。

这本书描述了windows调试器windbg的使用(第一部分),如何利用这个工具解决调试中遇到的问题,如栈破坏、堆破坏等(第二部分),以及一些高级话题,比如自己编写扩展调试命令(第三部分),我在调试过程中一直没有找到命令可以查看ansi格式的中文字符串,du只能查看unicode16格式的,所以自己写了个可以方便查看。在工程中实际用到的另一个东西是查看minidump文件,不知道什么原因,visualstudio2008在很多情况下查看的栈信息并不对,而windbg则没这问题

与visualstudio调试工具相比,windbg采用的不同的调试引擎,visualstudio调试功能其实也很强大,但是都是用户态的,有些东西不确定能不能查看,比如查看句柄之类的,还有内存泄露查看相关,这本书中则介绍了如何使用windbg查看内存堆,查看句柄等方法,visualstudio的优势是集成开发环境,使用起来更加方便,windbg则功能更加强大,但是不得不在文本编辑、调试器、编译器工具之间来回切换。对于我自己的项目开发,visualstudio的一个很大缺点是运行速度太慢了,可能是项目比较大的缘故。

想深入了解windows调试比较底层的知识(栈、堆、内存、各种windows内核对象),这本书+windbg帮助文件+google是很好的选择


代码相关

代码下载:前言示例代码种有网址

代码编译:

工具:下载WDK,其中包含一个完整

该资源有目录,对大家学习调试技术会有很大的帮助 译 者 序 软件调试是开发人员日常工作的重要组成部分。无论软件工程的理念多么先进,开发进度的安排多么合理,或者开发人员的经验多么丰富,人们在开发软件时总是无法保证不出现任何错误。当软件出现错误时,就需要进行调试。近年来,随着软件规模和复杂性的不断增加,错误的出现频率以及调试难度也在以非线性的方式增长。要想提高调试工作的效率,采用正确的调试思路和调试工具是非常重要的。有时候,一个需要数天时间才能解决的问题,如果换一种调试思路或者借助某种特殊的调试工具,或许只需1个小时就可以解决。 软件人员通常都知道许多高效的编码方法,例如极限编程、代码自动生成框架等,但他们很少知道一些高效的调试方法。大多数软件开发人员的调试思路和所使用的调试工具都还停留在比较初级的阶段,例如仅限于通过集成开发环境自带的调试器来进行单步跟踪。事实上,随着Windows的不断发展,Windows调试工具的数量和功能也在不断增加。但可惜的是,很少有人知道这些强大的调试工具,而了解这些工具的独特优势并且针对不同调试问题采用正确调试工具的人则更少。有些软件开发人员经常加班和熬夜,往往是因为他们使用了一些低效的方法来调试复杂的问题,他们并不知道其实存在着一些更高效的调试方式可以帮他们节约大量的时间。 本书的写作初衷正是为了将一些非常有价值的调试思路和调试工具推荐给软件开发人员,目的是提高开发人员的调试效率。本书的特点如下。 1) 系统地介绍了Windows调试的基础知识。这些知识包括两个方面:Windows中一些底层组件的知识,包括调用栈的结构、堆管理器的工作原理、安全管理机制、进程间通信协议等;一些基本的调试知识,包括调试器的工作原理、调试符号的使用、内存转储文件的结构以及栈回溯中包含的调试信息等。 2) 结合实际问题来阐述正确的调试思路以及各种调试工具的使用。本书采用的叙述方式是,首先给出某个实际的问题,例如内存破坏、同步问题、资源泄漏、安全威胁等;然后介绍分析这个问题的正确调试思路,例如如何通过程序的异常表现来了解问题的具体信息;最后根据所调试的问题来采用正确的调试工具,并详细讲解了各种调试工具的使用方法和技巧。 3) 讲解了一些高级调试主题,包括64位操作系统上的调试Windows Vista系统上的调试、事后调试以及调试扩展的编写等。这些主题为开发人员进行复杂的调试提供了必要的基础知识。 作者Mario Hewardt和Daniel Pravat是Microsoft公司的资深工程师,他们从事的工作就是保证Windows产品的可靠性、稳定性以及安全性。他们在调试领域已经工作了十余年的时间,积累了丰富的调试实践经验,而本书正是融合了这些宝贵的经验而形成的。因此,对于Windows开发人员来说,本书是一本不可多得的调试参考手册。 本书的技术性较强,需要读者对Windows系统的底层架构和组件有一定的了解,并且具备一定的编程基础和调试基础。如果读者需要补充这些方面的知识,可以参考作者在书中介绍的相关参考书籍。 参与本书翻译工作的还有李杨、吴汉平、徐光景、童胜汉、陈军、胡凯、刘红、张玮、陈红、李斌、李勇涛、王海涛、周云波、彭敏才和张世锋等。由于译者的时间和水平有限,翻译中的疏漏和错误在所难免,请读者和同行不吝指正。 感谢妻子云兰和女儿彤彤,虽然在翻译本书的过程中减少了陪伴你们的时间,但你们依然理解和支持我的工作。感谢父母在生活上的帮助,使我可以全身心地投入到本书的翻译工作中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值