- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
CallStack调用栈:用调试器脚本查看调用栈
信息
#include
int SumToOne(int d, int sum)
{
sum += d;
if (d != 1)
sum = SumToOne(d-1, sum);
else
sum = sum; // 这条语句便利设置断点
return sum;
}
void main()
{
int sum = SumToOne(10, 0);
printf( “sum=%d “, sum);
}
然后,在当前文件夹下,编辑调试器脚本文件DumpStack.txt,内容
如下
.printf “Dump %d framesn “, ${$arg1}
r $t1=@ebp;
.for (r $t0=1; $t0aaaa “dumpStack.txt “ a)
脚本变量的赋值和引用:这里使用了windbg 别名(alias)的语法,大
家可以把别名类比成 c 中的宏。在赋值的时候,用r $别名= 的格式,引
用的时候,使用$别名
取值操作:c 中的*p 操作在 windbg 中,要用 poi(p),缘由是由于
windbg 默认支持 MSAM 语法。
掌握语句:.for 语句的使用和任何一种语言的 for 语句思想一样,
不再多述
输出语句:.printf 和 c 中的printf 也根本相像,这里也不多述
了解了语法之后,来看看算法:
脚本通过 poi($t1+8), poi($t1+c)来显示每个 frame 中d 和 sum 的
值,这里$t1 代表了每个 frame 中ebp 的值,所以简洁的说,就是把每个
frame 中 ebp+8,ebp+c 的值输出。在介绍调用商定的博客中,我叙述了
这个偏移量的由来,在这里重温一下。由于函数 SumToOne 是 stdcall,
压栈挨次从右往左,如下表所示
前一个 ebp
eip
d
sum
ebp 指向存储前一个 ebo 的位置,所以 d 的位置在ebp+8,sum 在 ebp+c
前往下一个 frame,只需要把栈上 ebp 位置的值取出,作为新的 ebp
就可以了。由于根本上每一个程序在进展栈操作之前都会备份老的
ebp(push ebp),然后把当前的 esp 作为新的 ebp(mov ebp, esp)
总结一下,今日这篇博文作为这个系列的完毕,通过一个调式器脚本,
复习了之前叙述的调用栈的相关概念。同时也展现了调试器脚本的相关语
法。
您可能关注的文档
最近下载
- 钢结构吊装专项施工方案(技术方案).doc
- 中国成人念珠菌病诊断与治疗专家共识解读PPT课件.pptx VIP
- 05S804:矩形钢筋混凝土蓄水池.pdf VIP
- 01-泌尿系统疾病总论.ppt VIP
- 物理治疗学神经生理疗法Bobath技术.docx VIP
- Unit 3 My favourite food Lesson 2 Happy birthday, Amber! 单元教学设计 粤教沪外教版英语三年级下册.docx
- Andrews分析法诊断正畸.pptx
- (新课程中小学科学教学设计与案例分析提纲及答案2.doc VIP
- 2025年湖北省遴选面试真题及答案大全解析.docx VIP
- DB11T 1832.15-2022 建筑工程施工工艺规程 第15部分:通风与空调安装工程 conv.docx VIP
原创力文档


文档评论(0)