i++ 与 ++i 的执行过程

经常遇到一连串的 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++ 高. 

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值