如何根据内存地址定位出错的源代码行?
相信很多人都遇到过内存错,可能是因为写一段只读的内存,或者是由于一个空指针,如果没有适当的进行异常处理,一个精心设计的软件可能就会因为一个小小的异常而很不体面地被windows终结,得到类似下面的一个对话框:
一旦出现上面的对话框,特别是在给用户演示的时候,可不仅仅是颜面扫地的问题,可能就因此丢了一个大单子。作为一个技术人员,在懊恼之余,还得修改这个bug的,仅仅从上面的对话框中,我们除了知道是一个空指针引起的问题外,怎么知道源代码中那一行代码出错了呢?
下面以一个小例子演示如何解决这个问题。启动Delphi(2007),建立一个VCL Form Applcation,引发异常的代码如下:
大家应该一眼就看出哪一行代码出问题了吧?
现在到了关键部分,在项目选项对话框中把“Map file”置为“Detailed”,这将导致linker为我们生成map文件(map文件是什么?自己baidu去o(∩_∩)o),本文的核心就是从map文件中找到我们需要的信息。
首先从出错对话框中记下出错的内存地址“00454e07”,打开map文件(editplus,ue,vi,notepad……),进入视野的是如下内容:
Start L

当遇到内存错误时,通过记录的内存地址,可以从Map文件中找出错误发生的代码段和函数,甚至精确到出错的源代码行。本文以Delphi为例,介绍了如何设置生成详细的Map文件,然后分析Map文件来定位问题。
最低0.47元/天 解锁文章
6202

被折叠的 条评论
为什么被折叠?



