C语言++i和i++
2016-08-06 00:37
78 查看
i和i的区别
C代码
汇编代码
解释说明
i++表示取i的地址,把它的值装入寄存器中,然后增加内存中i的值
leal 1(%rax), %edx 的意思是 rax的值+1 存放到edx
当然这是个技巧了,正规做法得两条指令才能实现上述功能
movl %eax, %edx
addl $1, %edx
当然,此处是gcc进行了优化,其它编译器不一定会这么做
C代码
汇编代码
解释说明
++i和i++的区别
++i表示取i的地址,增加它的内容,然后把值装入寄存器中i++表示取i的地址,把它的值装入寄存器中,然后增加内存中i的值
C代码
int main() { int ret = 0; int i = 2; ret = i++; ret = ++i; return ret; }
汇编代码
gcc -S 编译上述c代码生成汇编代码如下.file "assam.c" .text .globl main .type main, @function main: .LFB0: .cfi_startproc pushq %rbp .cfi_def_cfa_offset 16 .cfi_offset 6, -16 movq %rsp, %rbp .cfi_def_cfa_register 6 movl $0, -4(%rbp) movl $2, -8(%rbp) movl -8(%rbp), %eax leal 1(%rax), %edx # i++ movl %edx, -8(%rbp) # i=i+1 movl %eax, -4(%rbp) # ret=i addl $1, -8(%rbp) # ++i即i=i+1 movl -8(%rbp), %eax movl %eax, -4(%rbp) # ret=i+1 movl -4(%rbp), %eax popq %rbp .cfi_def_cfa 7, 8 ret .cfi_endproc .LFE0: .size main, .-main .ident "GCC: (GNU) 4.8.5 20150623 (Red Hat 4.8.5-4)" .section .note.GNU-stack,"",@progbits
解释说明
指令 leal 的作用是load effective address, 本用于地址操作的leal 1(%rax), %edx 的意思是 rax的值+1 存放到edx
当然这是个技巧了,正规做法得两条指令才能实现上述功能
movl %eax, %edx
addl $1, %edx
当然,此处是gcc进行了优化,其它编译器不一定会这么做
相关文章推荐
- 如何组织构建多文件 C 语言程序(二)
- 如何写好 C main 函数
- Lua和C语言的交互详解
- 关于C语言中参数的传值问题
- 简要对比C语言中三个用于退出进程的函数
- 深入C++中API的问题详解
- 基于C语言string函数的详解
- C语言中fchdir()函数和rewinddir()函数的使用详解
- C语言内存对齐实例详解
- C语言编程中统计输入的行数以及单词个数的方法
- C 语言简单加减乘除运算
- C语言自动生成enum值和名字映射代码
- C语言练习题:自由落体的小球简单实例
- 使用C语言判断英文字符大小写的方法
- c语言实现的带通配符匹配算法
- C语言实现顺序表基本操作汇总
- C语言中进制知识汇总
- C语言判断一个数是否是2的幂次方或4的幂次方
- C语言二进制思想以及数据的存储
- C语言中计算正弦的相关函数总结