微笑的好吧 发表于 2014-10-18 15:13:29

简单C程序与反汇编问题 求指点

#include <stdio.h>
#include <stdlib.h>

int main()      //一个简单的C程序
{
    int i;
    for(i = 0;i < 5;i++)
    {
      printf("3");
    }
    printf("\n");
    return 0;
}

0x00401334        push   %ebp
0x00401335        mov    %esp,%ebp
0x00401337        and    $0xfffffff0,%esp
0x0040133A        sub    $0x20,%esp
0x0040133D        call   0x401930 <__main>
0x00401342        movl   $0x0,0x1c(%esp)
0x0040134A        jmp    0x40135c <main+40>
0x0040134C        movl   $0x33,(%esp)
0x00401353        call   0x401ba0 <putchar>
0x00401358        incl   0x1c(%esp)
0x0040135C        cmpl   $0x4,0x1c(%esp)
0x00401361        jle    0x40134c <main+24>
0x00401363        movl   $0xa,(%esp)
0x0040136A        call   0x401ba0 <putchar>
0x0040136F        mov    $0x0,%eax
0x00401374        leave
0x00401375        ret

这个是随便写了一个简单的C程序以及在code blocks 中调试且反汇编
得到的汇编代码。
其实我也没有什么问题{:7_122:},本来我看甲鱼哥汇编教程的时候,总有一些ax,bx之类的
完整的语句(比如说movax , 1)但是怎么这里我就迷糊了呢?!{:7_133:}
这里有一些美元的符号,和一些百分号是怎么一回事呀,求指点。{:7_132:}

楚门 发表于 2014-10-18 15:22:26

本帖最后由 楚门 于 2014-10-18 15:23 编辑

鱼哥讲汇编用的是王爽的《汇编语言》这本书作为教材,这本教材使用的是intel的汇编语法,而code blocks只是一个管理工程代码的工具,它内部调用的的编译器默认是GCC的编译器(在windows下的版本),而gcc编译器使用的是AT&T的汇编语法,其实这两者之间的语法差别不太多,只是寄存器写法的顺序是相反的,还有立即数前面要加$,寄存器前面要加%,另外就是寻址方式的写法有些不同,当然可能还有一些细节没说到,你可以在网上找找关于AT&T汇编语法资料具体看看

微笑的好吧 发表于 2014-10-18 21:01:28

楚门 发表于 2014-10-18 15:22
鱼哥讲汇编用的是王爽的《汇编语言》这本书作为教材,这本教材使用的是intel的汇编语法,而code blocks只是 ...

简洁明了。谢谢。

大个的糖果 发表于 2014-10-30 17:34:31

页: [1]
查看完整版本: 简单C程序与反汇编问题 求指点