x=x+1,x+=1,x++效率的两种说法

有次翻关于招聘的书,上面有道题:x=x+1,x+=1,x++,哪个效率最高?我上网查后发现,有以下2种说法:

	x=x+1最低,因为它的执行过程如下:

  1. 读取右x的地址;

  2. x+1;

  3. 读取左x的地址;

  4. 将右值传给左边的x(编译器并不认为左右x的地址相同).

  x+=1其次,它的执行过程如下:

  1. 读取右x的地址;

  2. x=1;

  3. 将得到的值传给x(因为x的地址已经读出).

  x++最高,它的执行如下:

  1. 读取右x的地址;

  2. x自增1.

仔细想想,觉得有些不对劲,遂又发现一篇博文:

某书上说是x=x+1效率最低,x+=1次之,x++效率最高,并解释了一大堆理由。我是没看明白,因为想来想去这3条语句都应该对应两次访内操作,一次加法操作,所以效率应该一样。用VC编译后看了下其汇编指令,证实了我的想法:

VC2003不开任何编译优化开关,3条C语句对应的汇编指令相同:
mov         eax,dword ptr [x]
add         eax,1
mov         dword ptr [x],eax

VC2003打开编译优化开关(O2),3条C语句对应的汇编指令仍然相同,只不过加法指令现在换成了加1指令
mov         eax,dword ptr [x]
inc         eax
mov         dword ptr [x],eax

然后又在http://stackoverflow.com/questions/7471891/is-x-1-more-efficient-than-x-x-1发现,基本都是认为,这取决于编译器,而且一般情况下3者效率一样

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值