反汇编系列(二) 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语言代码,无法直接给出switch语句的汇编。但是,我们可以根据您提供的信息,简单介绍一下switch语句的汇编实现方式。 在汇编语言中,switch语句通常被转换为一系列的条件分支指令,例如cmp和je指令。具体实现方式取决于编译器和处理器架构。在x86架构中,通常使用跳转表(jump table)来实现switch语句。跳转表是一个数组,其中每个元素都是一个指向代码的指针。当执行switch语句时,程序会计算出一个索引值,然后跳转到跳转表中对应的指针所指向的代码位置。 下面是一个简单的C语言switch语句的示例代码: ```c switch (x) { case 0: // do something break; case 1: // do something else break; default: // do something else break; } ``` 下面是该代码的汇编实现方式: ```assembly cmp eax, 0 je label1 cmp eax, 1 je label2 jmp default_label label1: ; code for case 0 jmp end_switch label2: ; code for case 1 jmp end_switch default_label: ; code for default case end_switch: ; code after switch statement ``` 在上面的汇编代码中,eax寄存器存储了switch语句的条件变量x的值。首先,程序会将eax的值与每个case语句中的常量进行比较,如果相等,则跳转到对应的标签(label1或label2)处执行相应的代码。如果没有匹配的case语句,则跳转到default_label处执行默认代码。最后,程序会跳转到end_switch处执行switch语句后面的代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值