经常遇到一连串的 i++ 或者 ++i 相加,问最后执行的结果和 i 的值
i.g
int i = -1;
int y = 0;
y = i++ + ++i;
分析一下它的汇编代码(没有经过优化):
subl $40, %esp ; 分配40字节
movl $1, -16(%ebp) ; 存储 i
movl $0, -12(%ebp) ; 存储 y
movl -16(%ebp), %eax ; 这3步执行 i++
leal 1(%eax), %edx
movl %edx, -16(%ebp)
addl $1, -16(%ebp) ; 这2步执行 ++i
movl -16(%ebp), %edx
addl %eax, %edx ; 相加操作
movl %edx, -12(%ebp) ; 结果写回 y
可以看出执行 i++ 需要3步,执行 ++i 需要2步,而且修改 i 值的位置是不一样的.
这也是为什么再写for循环的时候,++i 的效率会比 i++ 高.