x=x+1,x+=1,x++效率的两种说法
来源:互联网 发布:女士香水推荐 知乎 编辑:程序博客网 时间:2024/05/16 09:57
有次翻关于招聘的书,上面有道题: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
add
mov
VC2003打开编译优化开关(O2),3条C语句对应的汇编指令仍然相同,只不过加法指令现在换成了加1指令
mov
inc
mov
然后又在http://stackoverflow.com/questions/7471891/is-x-1-more-efficient-than-x-x-1发现,基本都是认为,这取决于编译器,而且一般情况下3者效率一样
0 0
- x=x+1,x+=1,x++效率的两种说法
- x=x&(x-1)
- x=x&(x-1)
- x = x&(x-1)
- x = x&(x-1)
- 题目:x=x+1; x+=1;x++的效率那个高?
- x=x+1,x+=1,x++的效率问题?
- x=x+1,x+=1及x++的效率哪个最高?
- x=x+1,x+=1,x++的效率哪个最高?
- X=X+1,X+=1,X++这三种使用方式的效率比较
- 关于x=x+1、x+=1、x++的执行效率问题
- x = x+1,x+=1,x++那个的执行效率高
- x=x+1,x+=1,x++三个式子的效率谁最高
- x=x+1, x+=1, x++的执行效率比较
- x=x+1,x+=1,x++的区别
- x &= (x-1)
- x&(x-1)=?
- x=x+1、x+=1、x++、++x
- Quartus11.0下载地址及详细安装步骤
- SQL2000数据库查询讲解003--消除重复的行
- halt,shutdown,reboot,init的差异
- Java NIO系列教程(四) Scatter/Gather
- Twitter Storm源代码分析之DRPC架构细节
- x=x+1,x+=1,x++效率的两种说法
- linux内核版本号说明
- Redis 数据库
- Java NIO系列教程(五) 通道之间的数据传输
- mybatis 自动生成配置文件
- ERP项目实施记录05
- oracle 删除已存在进程
- 继承和组合
- 2013年自我回顾与总结(1)