zoukankan      html  css  js  c++  java
  • 一段简单c程序的汇编语言学习(ubuntu+x86)

    c程序代码:

    #include <stdio.h>
    
    int main(void)
    {
    	int i=0, j=0;
    
    	for(i=0; i<8; i++)
    		j=j+1;
    
    	return 0;
    }
    


    汇编代码如下:

    .file   "test_asm.c"
          2     .text
          3     .globl  main
          4     .type   main, @function
          5 main:
          6 .LFB0:
          7     .cfi_startproc
          8     pushl   %ebp
          9     .cfi_def_cfa_offset 8
         10     .cfi_offset 5, -8
         11     movl    %esp, %ebp
         12     .cfi_def_cfa_register 5
         13     subl    $16, %esp
         14     movl    $0, -8(%ebp)
         15     movl    $0, -4(%ebp)
         16     movl    $0, -8(%ebp)
         17     jmp .L2
         18 .L3:
         19     addl    $1, -4(%ebp)
         20     addl    $1, -8(%ebp)
         21 .L2:
         22     cmpl    $7, -8(%ebp)
         23     jle .L3
         24     movl    $0, %eax
         25     leave
         26     .cfi_restore 5
         27     .cfi_def_cfa 4, 4
         28     ret
         29     .cfi_endproc
         30 .LFE0:
         31     .size   main, .-main
         32     .ident  "GCC: (Ubuntu/Linaro 4.7.3-1ubuntu1) 4.7.3"
         33     .section    .note.GNU-stack,"",@progbits
    

    汇编代码讲解:

    第8行:将栈基址指针(存在ebp寄存器)推入栈
    第11行:将栈指针移入基址指针(esp为基址寄存器)

    第13行:从ebp开始分配16字节的内存

    第14,15,16行:将i, j赋初值0

    第17行:.L2为编译器创建的标号,并跳到.L2执行

    第22,23行:将i的与常量7比较,成立则跳到.L3执行

    第18行:将j的值加1,i的值加1

    最后几行释放局部内存区,并跳转回调用程序(ret)

  • 相关阅读:
    静态方法中访问类的实例成员
    静态初始化块
    Java字段初始化的规律
    java中函数重载
    哈姆雷特观后感 一把辛酸泪
    枚举
    验证码
    四则运算
    JAVA输出中+号的作用以及如何使用
    dev控件ASPxComboBox设置ReadOnly="true"后
  • 原文地址:https://www.cnblogs.com/aukle/p/3223572.html
Copyright © 2011-2022 走看看