​Delphi通过Map文件查找内存地址出错代码所在行​

news/2024/7/5 1:45:24

一 什么是MAP文件

      什么是 MAP 文件?简单地讲, MAP 文件是程序的全局符号、源文件和代码行号信息的唯一的文本表示方法,它可以在任何地方、任何时候使用,不需要有额外的程序进行支持。而且,这是唯一能找出程序崩溃的地方的救星。

      如果要查找代码行号,需要使用下面的公式做一些十六进制的减法运算:

      崩溃行偏移 = 崩溃地址(Crash Address) - 基地址(ImageBase Address) - 0x1000

      为什么要这样做呢?我们得到的崩溃地址都是由 偏移地址+ 基地址得来的,所以在计算行号的时候要把基地址减去,一般情况下,基地址的值是 0x00400000 。另外,由于一般的 PE 文件的代码段都是从 0x1000 偏移开始的,所以也必须减去 0x1000 。

二 Delphi 下生成MAP文件的方法 

      project   ->   options   ->   Linker   ->   Map   file   选择detailed。  生成的位置在Exe文件所在的目录。

三 例子

      代码

procedure TForm1.Button1Click(Sender: TObject);
 

var     
 

    I,   J:   Integer;
 

    p:   PChar;
 

begin
 

    I   :=   10;
 

    J   :=   0;
 

    p   :=   nil;
 

    p^   :=   'A';   //   36行.  这里会报错
 

end;

     运行时会报错

这里可以发现出错地址是:$00401A51

根据:      崩溃行偏移 = 崩溃地址(Crash Address) - 基地址(ImageBase Address) - 0x1000

                                     =$00401A51 - $00400000 -$1000

                                    =$00000A51

用记事本打开生成的MAP文件
 

Line numbers for Unit1(Unit1.pas) segment .text
 


 

    32 0001:00000A48    35 0001:00000A49     36 0001:00000A4E    37 0001:00000A54
 

    40 0001:00000A58    42 0001:00000A7D    43 0001:00000A8E    44 0001:00000ABD
 

    45 0001:00000AEE    49 0001:00000AF8    50 0001:00000B10    52 0001:00000B44
 

    52 0001:00000B4B
 

那么,通过在MAP文件里查找小于或等于$00000A51的最大值就是,我们要得到的崩溃行偏移.

这样得到出错行在, Unit1单元的36行.  正好是这行:   p^   :=   'A';   //   36行.  这里会报错

建议给客户的时候不要带着map文件,map文件里记录着所有程序函数的名称及入口内存地址,太方便别人破解了。


http://lihuaxi.xjx100.cn/news/2204179.html

相关文章

WWDC 2024:苹果将​​在 iOS 18 中对 Siri 进行人工智能升级,集合多项人工智能功能

虚拟助手正在获取 ChatGPT 并进行更新,以提高响应速度并提供新的人工智能功能。 苹果公司宣布其 Siri 虚拟助手将具备多项人工智能功能,例如更新的设计、改进其说话和理解口语命令的方式,以及与 OpenAI 的 ChatGPT 模型的集成。 其中一些功…

【电赛】STM32-PID直流减速电机小车【寻迹+避障+跟随】【更新ing】

一.需求分析 1.主控:STM32C8T6(没什么好说的哈哈) 2.电机:JAG25-370电机 【问】为什么要用直流减速电机?? PID控制器需要依靠精确的反馈信号来调整其输出,确保电机按照预定的速度和位置运行…

DeepSpeed Learning Rate Scheduler

Learning Rate Range Test (LRRT) 训练试跑,该lr scheduler从小到大增长lr,同时记录下validatin loss;人来观察在训练多少step之后,loss崩掉(diverge)了,进而为真正跑训练,挑选合适的lr区间&…

内存经验分享

目录 内存统计工具 /proc/meminfo Buddy ​​​​​​​​​​​​​​Slub ​​​​​​​Procrank /proc/pid/smaps ​​​​​​​Dumpsys meminfo 内存评估 内存泄漏 Lmk 水位调整 内存统计工具 /proc/meminfo 可以提供整体内存信息,各字段表示的意思如…

冯喜运:6.11最新黄金原油趋势解析及独家多空操作建议

【黄金消息面分析】:周二(6月11日)亚市早盘,现货黄金窄幅震荡,目前交投于2310.15美元/盎司附近。黄金价格在上一交易日创下三年半来最大单日跌幅后于周一反弹,收报2310.71美元/盎司附近,投资者在…

如何发挥物联网电能表的优势

发挥物联网电能表的优势,对于提升电力系统的智能化水平、优化电力资源配置、提高用电效率以及促进环保发展等方面都具有重要意义。 一、实时监测与数据分析 物联网电能表的核心优势在于其能够实时监测电力使用情况,并通过无线网络将数据传输到云平台。…

初阶 《函数》 4. 函数的调用

4. 函数的调用 4.1 传值调用 函数的形参和实参分别占有不同内存块,对形参的修改不会影响实参 4.2 传址调用 传址调用是把函数外部创建变量的内存地址传递给函数参数的一种调用函数的方式 这种传参方式可以让函数和函数外边的变量建立起真正的联系,也就是…

DDoS攻击与防御

DDoS攻击类型 DDoS攻击(分布式拒绝服务攻击)有多种类型,每种类型都有其特定的攻击方式和目标。以下是DDoS攻击的主要类型及其简要描述: 应用层攻击: 这类攻击也称为第7层攻击,主要目标是耗尽目标服务器的资源,从而创建拒绝服务的状态。攻击者会发送大量的HTTP请求等到服…