3476|13

71

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

i++和i--的效率哪个高?为什么呢嚎? [复制链接]

朋友问我2个for循环的语句的效率哪个高?如何判断?
for(int i = 0;   i<100 ; i++);
for(int i =100; i>0 ; i--);
我的解决方法就是把上面的语句反汇编,通过看汇编代码来判断这2个for循环效率的差异。
但比较下来,2个反汇编的汇编语句的条数是一样的,汇编语句有不一样,我想找汇编指令所占的机器时间又没找到。在网上搜索和问人,都说是i++和i--的差别,有说i--效率高的,也有说i++效率高的,但都说不出是为什么,所以请哪位朋友知道的,帮下忙,谢谢了

最新回复

我个人感觉i--高一些。 这是为什么呢? 因为如果和i比较的不是一个立即数而是一个变量那么这就有区别了。 不过在通常的习惯下,大家都习惯于i++.   详情 回复 发表于 2009-4-3 17:18
点赞 关注

回复
举报

74

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
这要根据具体的CPU来说,指令系统不一样结果就不一样,比如51单片机,它有一条DJNE指令,这样如果用i--的话,这一条指令就可以完成--并判断跳转的功能,而如果用i++的话,它就要用一条INC,或者ADD指令来配合跳转,所以在51里用i--效率要高。但是如果是ARM,两者的效果是一样的。你可以自己写一条简单的for语句来看看编译出来的汇编代码。如果经过编译器优化那就没试过。
 
 

回复

79

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
要看什么平台、编译器的优化==
最终要看生成的机器指令是什么样的。1楼说得很对。
 
 
 

回复

86

帖子

0

TA的资源

一粒金砂(初级)

4
 
研究这个真够囧的
 
 
 

回复

82

帖子

0

TA的资源

一粒金砂(初级)

5
 
不如把时间花在程序优化上,这个不要计较吧
 
 
 

回复

92

帖子

0

TA的资源

一粒金砂(初级)

6
 
引用 4 楼 hudaweikevin 的回复:
不如把时间花在程序优化上,这个不要计较吧


同意4楼的看法,一个解决策略上的优化可以使整个程序的效率成百倍的提高,这才是提高效率的核心所在。
 
 
 

回复

91

帖子

0

TA的资源

一粒金砂(初级)

7
 
问题研究的很深入,值得学习。
 
 
 

回复

66

帖子

0

TA的资源

一粒金砂(初级)

8
 
引用 1 楼 guetcw 的回复:
这要根据具体的CPU来说,指令系统不一样结果就不一样,比如51单片机,它有一条DJNE指令,这样如果用i--的话,这一条指令就可以完成--并判断跳转的功能,而如果用i++的话,它就要用一条INC,或者ADD指令来配合跳转,所以在51里用i--效率要高。但是如果是ARM,两者的效果是一样的。你可以自己写一条简单的for语句来看看编译出来的汇编代码。如果经过编译器优化那就没试过。


以下是我从别的论坛上得到的答案,不知道对不对:
我认为关键在比较那个指令上
如是i--时,因为是和0比较,所以可使用
test eax,eax  ;直接寄存器比较,速度能加快吧
jnz XXXXXXX
这样的

使用i++时,因为是和100比较,所以要使用
cmp eax,100      ;和立即数比较,指令使用花的时间长
jnz xxxxxxxx
 
 
 

回复

71

帖子

0

TA的资源

一粒金砂(初级)

9
 
引用 1 楼 guetcw 的回复:
这要根据具体的CPU来说,指令系统不一样结果就不一样,比如51单片机,它有一条DJNE指令,这样如果用i--的话,这一条指令就可以完成--并判断跳转的功能,而如果用i++的话,它就要用一条INC,或者ADD指令来配合跳转,所以在51里用i--效率要高。但是如果是ARM,两者的效果是一样的。你可以自己写一条简单的for语句来看看编译出来的汇编代码。如果经过编译器优化那就没试过。


以下是我从别的论坛上得到的答案,不知道对不对:
我认为关键在比较那个指令上
如是i--时,因为是和0比较,所以可使用
test eax,eax  ;直接寄存器比较,速度能加快吧
jnz XXXXXXX
这样的

使用i++时,因为是和100比较,所以要使用
cmp eax,100      ;和立即数比较,指令使用花的时间长
jnz xxxxxxxx
 
 
 

回复

64

帖子

0

TA的资源

一粒金砂(初级)

10
 
引用 1 楼 guetcw 的回复:
这要根据具体的CPU来说,指令系统不一样结果就不一样,比如51单片机,它有一条DJNE指令,这样如果用i--的话,这一条指令就可以完成--并判断跳转的功能,而如果用i++的话,它就要用一条INC,或者ADD指令来配合跳转,所以在51里用i--效率要高。但是如果是ARM,两者的效果是一样的。你可以自己写一条简单的for语句来看看编译出来的汇编代码。如果经过编译器优化那就没试过。


以下是我从别的论坛上得到的答案,不知道对不对:
我认为关键在比较那个指令上
如是i--时,因为是和0比较,所以可使用
test eax,eax  ;直接寄存器比较,速度能加快吧
jnz XXXXXXX
这样的

使用i++时,因为是和100比较,所以要使用
cmp eax,100      ;和立即数比较,指令使用花的时间长
jnz xxxxxxxx
 
 
 

回复

79

帖子

0

TA的资源

一粒金砂(初级)

11
 
这两个都是一样的,在ARM里除了乘除法指令都是单周期指令。只不过有些立即数需要伪指令来加载。
 
 
 

回复

67

帖子

0

TA的资源

一粒金砂(初级)

12
 
问问小沈阳。。
 
 
 

回复

74

帖子

0

TA的资源

一粒金砂(初级)

13
 
这个问题问了很多次了,一样高,因为2者的汇编代码一致
 
 
 

回复

69

帖子

0

TA的资源

一粒金砂(初级)

14
 
我个人感觉i--高一些。
这是为什么呢?
因为如果和i比较的不是一个立即数而是一个变量那么这就有区别了。
不过在通常的习惯下,大家都习惯于i++.
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表