- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C程序运行时内存结构分析
时间:2015-11-24 22:25????点击:37次
实验知识
静态变量存储在静态存储区,局部变量存储在动态存储区(栈),代码存放在代码区
寄存器,EBP指向栈底,ESP指向栈顶,EIP指向正在执行指令的下一条指令,三个寄存器中保存的都是地址,32位系统,地址为4个字节即dword
所有写在函数定义里面的语句都编译成指令(驱动CPU)
实验代码
#include stdio.h
int?fun(int?a,?int?b);
int?m = 10;
int?main()
{
????int?i = 4;
????int?j = 5;
????m = fun(i, j);
}
int?fun(int?a,?int?b)
{
????int?c = 0;
????c = a + b;
????return?c;
}这段代码包含两个函数,因此可以测试函数调用,此外还包含了静态变量、局部变量、返回值等
实验测试
测试工具:VC6.0
源代码及对应的汇编如下
INCLUDEPICTURE \d /uploads/allimg/151124/22261CQ8-0.png \* MERGEFORMATINET
INCLUDEPICTURE \d /uploads/allimg/151124/2226161615-1.png \* MERGEFORMATINET
寄存器及内存状态如下
INCLUDEPICTURE \d /uploads/allimg/151124/2226164359-2.png \* MERGEFORMATINET
EBP栈顶初始值为0018FF84h,ESP初始为0018FF48h
ESP和EBP在栈中的作用
在每个函数最开始的地方有两条语句
push ebp
mov ebp,esp
在函数返回前也有两条语句
mov esp,ebp
pop ebp每运行一个函数就新开一段栈空间,所谓的开栈空间就是移动ebp栈底,在移动ebp之前,通过push ebp保存上一级函数的栈底,然后用ebp指向现在函数栈的栈顶,即为当前函数开辟了栈;接着给局部变量进行地址分配以及保存现场等,esp不断向低地址移动,当函数调用结束时,esp指回当前函数的栈顶(mov esp,ebp),然后上一级函数的栈顶地址出栈保存在ebp中(pop ebp)。因此,每一个函数的栈顶上面都保存着上一级函数的栈顶地址,用于当前函数结束时能够返回上一级函数的栈,通过ebp和esp以及压栈出栈操作对栈进行维护。
逐条分析
main函数对应的汇编代码如下
7:????int?main()
8:??? {? push??????? ebp????????????????????????// ebp初始为0018FF84h压栈,压栈后esp = 0018FF48h - 4 = 0018FF44h? mov???????? ebp,esp????????????????????// ebp保存栈顶0,ebp=esp=0018FF44h? sub???????? esp,48h????????????????????// esp -= 48h开辟了一段栈空间,留待后面保存局部变量,此时esp=0018FF44h-48h=0018FEFCh? push??????? ebx???????????????????????? push??????? esi? push??????? edi????????????????????????// ebx、esi和edi压栈,esp = 0018FEFCh - 4*3 = 0018FEF0h? lea???????? edi,[ebp-48h]??????????????// lea指令将ebp-48h作为偏移地址保存在edi中,edi=0018FEFCh,即栈中ebx的上面
0040102C?? mov???????? ecx,12h???????????????????? mov???????? eax,0CCCCCCCCh? rep stos??? dword ptr [edi]????????????// 将eax重复保存在以edi开始的栈空间里,重复次数为ecx次,向高地址方向,共覆盖12h*4=48h个地址,即栈中保存ebx的地址以上到ebp指向的地址这一段全部填充为cch
9:??
您可能关注的文档
- 2015年全国中考数学分类专题40动态问题技术总结.doc
- 口腔组织病理学基础——牙体组织技术总结.ppt
- cs5460a程序答题.doc
- 《电子商务D》参考答题.doc
- CSC-196电力系统时间同步装置答题.docx
- 《电子商务概论》课后复习答题.doc
- 《电子设计创新实践(单片机)》任务书和指导书2016.6答题.doc
- 口试复习题技术总结.ppt
- 2015年全国中考物理60套:电压电阻(word版,31页)技术总结.doc
- 蝴蝶形态之神单理论技术总结.ppt
- 《GB/T 29025.1-2025粒度分析 电阻法 第1部分:小孔管法》.pdf
- 《GB/T 37034.2-2025航空电子过程管理 防伪 第2部分:来源于非授权经销商电子元器件的管理》.pdf
- 中国国家标准 GB/T 37034.2-2025航空电子过程管理 防伪 第2部分:来源于非授权经销商电子元器件的管理.pdf
- GB/T 6113.102-2025无线电骚扰和抗扰度测量设备和测量方法规范 第1-2部分:无线电骚扰和抗扰度测量设备 传导骚扰测量的耦合装置.pdf
- GB/T 13609-2025天然气 气体取样.pdf
- 中国国家标准 GB/T 13609-2025天然气 气体取样.pdf
- 《GB/T 13609-2025天然气 气体取样》.pdf
- GB/T 19629-2025医用电气设备 X射线诊断影像中使用的电离室和(或)半导体探测器剂量计.pdf
- 《GB/T 19629-2025医用电气设备 X射线诊断影像中使用的电离室和(或)半导体探测器剂量计》.pdf
- 中国国家标准 GB/T 19629-2025医用电气设备 X射线诊断影像中使用的电离室和(或)半导体探测器剂量计.pdf
最近下载
- 公共危机管理概论完整版ppt整本书教学教程最全电子教案(最新.pptx VIP
- 溃疡性结肠炎中医诊疗专家共识(2023).pptx VIP
- 小学课后延时服务建立良好的学习习惯.pptx VIP
- 2025年证券公司高级管理人员水平评价测试历年参考题库含答案详解(5套).docx VIP
- 2025年证券公司高级管理人员水平评价测试历年参考题库含答案详解.docx VIP
- 马克思主义哲学名著导读 第一编 马克思恩格斯的哲学名著.ppt VIP
- 大学生职业生涯规划人物访谈范例和报告.pdf VIP
- 项目全过程工程造价咨询招标文件模板.docx VIP
- 药剂学(本)形考任务1-3参考答案.docx VIP
- 2026北京中考英语听说考试应试技巧 课件.pdf
原创力文档


文档评论(0)