ImageVerifierCode 换一换
格式:DOCX , 页数:16 ,大小:1.99MB ,
资源ID:20852520      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/20852520.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(C语言与总汇编语言对照分析报告Word文件下载.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

C语言与总汇编语言对照分析报告Word文件下载.docx

1、c)for、while注:文中使用的反汇编工具为IDA一、汇编代码:if.else结构比较固定,通常包含cmp指令、jcc指令以及满足条件后执行的指令块。if.else结构可以串联,串联后的if.else有明显的代码块边界,逆向工具通常可以将代码块标识出来(图中虚线)。二、1.一个简单switch.case上图显示了switch.case基本的结构:跳转表达式;分支代码;跳转表跳转表达式其中loc_401235代码块对应switch.case中default分支。当nGameEvent4时,跳转到loc_401235代码块,即default分支。=4时,根据跳转表达式进行跳转:jmpds:of

2、f_40123CnGameEvent*4其中off_40123C为跳转表地址,跳转表中每一项代表一个32位地址(4个字节),当nGameEvent为0按第一项地址跳转,当nGameEvent为1按第二项地址跳转,依次类推。分支代码各个分支的处理逻辑都在这里,示例代码中仅仅简单的调用对应函数。(PS:这里用jmp而不用call是编译器优化的结果)跳转表实际是一个地址数组,存放了每个跳转分支的地址(32位绝对地址),当nGameEvent为0时,跳转表达式读取数组中第一项数据(0x0040121C),即.text:0040121CE98FFFFF+?DoLoginYAXXZ调用DoLogin函数。

3、(PS:实际运行时,由于随机化基址,从调试器看到的跳转表内容可能与静态分析时不同,这是重定位引起的,关于重定位的原理可以参考相关文档,这里不再详述)2.不连续的switch.case上面的示例中case的值是连续的,因此跳转表比较规则。在实际使用中可能会遇到不规则的case值,如下图:上面的代码有两个特点:i.最小case值非0上图中最小case值为3,为了不浪费跳转表空间,编译器会将索引值减去3保证最小的case值对应跳转表中的第一项。ii.case值不连续编译器会在跳转表间隔中插入default跳转,保证逻辑正确。(以空间换取时间)3.双重跳转表相对于前一个示例,此处case值间隔更大。如

4、果按照之前的方法,跳转表的大小需要(110-30+1)*4324字节,占用内存空间大。编译器为了节省空间,使用了双重跳转:跳转表、间接跳转表。其中跳转表与之前介绍的跳转表一致,而间接跳转表保存的不是分支地址,而是索引值,指向跳转表中的索引。跳转表:间接跳转表:在进入switch.case时,先算根据间接跳转表获得索引号,再根据索引号查找跳转表,获取实际分支地址。使用双重跳转表后,实际占用空间:5*4+(110301)=101字节,大大减少空间占用。4.swtich.case退化当case值间隔过大,使用跳转表、双重跳转表消耗的空间太大,编译器会将switch.case退化为if.else,如下

5、图:这里没有跳转表结构,只剩下cmp/jcc指令,可见编译器已经将swtich.case转换为等价的if.else。但在转换过程中,编译还是做了力所能及的优化:通过二叉查找法加快跳转分支的查找。5.嵌套switch.case可以看出嵌套的switch.case结构在汇编代码上是相对独立的,外层和内层switch结构有各自的跳转表。外层跳转表:内存跳转表(双重跳转表):根据跳转表中的地址项,也可以清楚的区分外层和内层的跳转分支。三、循环语句for循环其中nopdwordptreax+00h为指令对齐,没有实际意义。循环的汇编实现为:while循环ptreax+eax+00h从上面可以看出,for和while结构的汇编实现几乎一摸一样,仅仅是使用的寄存器有些区别。实际逆向过程中将循环映射为for或者while结构都是可以的。同时还可以看出,循环有个明显的特征:往回跳转(向地址小的方向跳转),大部分情况下遇到往回跳转的指令就是循环,极少数如编译器代码结构优化生成的往回跳转不是循环除外。四、总结语法结构对应的汇编代码与编译器有很大关系,同一份源代码不同编译器生成的汇编代码结构不一样;即使是同一个编译器,不同的编译选项生成的汇编代码结构也不尽相同。需要在逆向过程中慢慢熟悉编译器的特性。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1