反汇编系列(二) for

#include"stdio.h"
int function(int a,int b)
{
    int c=a+b;
    int i;
    for(i=0;i<50;i++)
    {
        c=c+i;
    }
    return c;
}
void main()
{
    function(1,2);
} 

--- c:\users\wangchao\desktop\test\test\main.cpp -------------------------------
#include "stdio.h"
int function(int a,int b)
{
011D1A40 push ebp
011D1A41 mov ebp,esp
011D1A43 sub esp,0D8h
011D1A49 push ebx
011D1A4A push esi
011D1A4B push edi
011D1A4C lea edi,[ebp-0D8h]
011D1A52 mov ecx,36h
011D1A57 mov eax,0CCCCCCCCh
011D1A5C rep stos dword ptr es:[edi]
    int c=a+b;
011D1A5E mov eax,dword ptr [a]
011D1A61 add eax,dword ptr [b]
011D1A64 mov dword ptr [c],eax
;---------------------------------------------------------------------------------------------
    int i;
    for(i=0;i<50;i++)
011D1A67 mov dword ptr [i],0         ;i=0
011D1A6E jmp function+39h (11D1A79h) ;跳转到判断i是否大于50
                                          ∧
011D1A70 mov eax,dword ptr [i]       ;    |
011D1A73 add eax,1                   ;执行了i=i+1
011D1A76 mov dword ptr [i],eax       ;    |
                                     ;    ∨
011D1A79 cmp dword ptr [i],32h       ;判断i是否大于50
011D1A7D jge function+4Ah (11D1A8Ah) ;如果大于等于50则跳出for循环,否则继续执行.                   
                                     ;    ∧
    {                                ;    |
        c=c+i;                       ;    |
011D1A7F mov eax,dword ptr [c]       ;执行了c=c+i;
011D1A82 add eax,dword ptr [i]       ;    |
011D1A85 mov dword ptr [c],eax       ;    |
    }                                ;    ∨
011D1A88 jmp function+30h (11D1A70h) ;如果不大于跳转到执行i++的位置
;---------------------------------------------------------------------------------------------
    return c;
011D1A8A mov eax,dword ptr [c]
}
011D1A8D pop edi
011D1A8E pop esi
011D1A8F pop ebx
011D1A90 mov esp,ebp
011D1A92 pop ebp

011D1A93 ret

--- c:\users\wangchao\desktop\test\test\main.cpp -------------------------------
void main()
{
011813E0 push ebp
011813E1 mov ebp,esp
011813E3 sub esp,0C0h
011813E9 push ebx
011813EA push esi
011813EB push edi
011813EC lea edi,[ebp-0C0h]
011813F2 mov ecx,30h
011813F7 mov eax,0CCCCCCCCh
011813FC rep stos dword ptr es:[edi]
    function(1,2);
011813FE push 2
01181400 push 1
01181402 call function (11810E6h)
01181407 add esp,8
}
0118140A xor eax,eax
0118140C pop edi
0118140D pop esi
0118140E pop ebx
0118140F add esp,0C0h
01181415 cmp ebp,esp
01181417 call @ILT+315(__RTC_CheckEsp) (1181140h)
0118141C mov esp,ebp
0118141E pop ebp

0118141F ret


基本结构:

   MOV <循环变量>,<初始值>     ;给循环变量赋初值
   JMP B                        ;跳到第一次循环处
A: (改动循环变量)              ;修改循环变量
   ...
B:CMP <循环变量>,<限制变量>   ;检查循环条件
   JGE 跳出循环
   ...
   JMP A   ;调回去修改循环变量

### C语言反汇编期末考试知识点总结 #### 1. 预处理器指令的作用及其影响 预处理阶段会解析并执行所有的宏定义、文件包含和其他预处理命令。这些操作不会生成机器码,而是修改源代码本身[^1]。 #### 2. 编译过程中的优化选项对最终进制的影响 不同的编译器优化级别会影响程序性能以及调试难度,在学习反汇编时了解这一点非常重要。例如 `-O0` 表示无优化而 `-O3` 则代表最高级别的优化。 #### 3. 汇编语言基础概念介绍 为了更好地理解C代码如何被转换成低级指令集架构(ISA),掌握基本的x86/x64汇编语法是必要的。这包括寄存器命名约定、寻址模式等。 #### 4. 关键字与数据类型的底层表示形式 熟悉诸如 `short`, `signed`, `sizeof`, `static`, `struct`, `switch`, `typedef`, `union`, `unsigned`, 和 `void` 这样的关键字对于分析反汇编后的代码至关重要。每种类型都有其特定内存布局和访问方式[^2]。 #### 5. 函数调用惯例的理解 函数参数传递机制、栈帧结构及返回地址保存位置都是逆向工程过程中经常遇到的概念。不同平台可能有不同的ABI标准。 #### 6. 基本控制流语句对应的汇编码片段 条件分支 (`if/else`)、循环(`for`,`while`) 等高级编程特性会被翻译成一系列跳转指令;通过研究这些对应关系可以加深对计算机体系结构的认识。 ```c // 示例:简单的 if-else 结构 int main() { int a = 5; if (a > 3) { printf("Greater than three\n"); } else { printf("Less or equal to three\n"); } } ``` 上述例子在经过编译之后会产生相应的比较和跳跃指令来实现逻辑判断功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值