for循环从大往小循环真的更加好吗?

2014-01-30 15:33:36 +08:00
 jacob
我的sublime text3,安装了emmet。输入for时会有自动完成,一共2中

//这种他叫“改进型内置for循环”

for (var i = Things.length - 1; i >= 0; i--) {
Things[i]
};

for (var i = 0; i < Things.length; i++) {
Things[i]
};

第一种和第二种在我眼中无非是顺序的区别,请问第一种真的比第二种好吗?
9275 次点击
所在节点    JavaScript
25 条回复
qiukun
2014-01-30 15:36:45 +08:00
区别在于 .length ,第一种不会比第二种差,这个理由足够吗?
rankjie
2014-01-30 15:36:46 +08:00
容易发现的一点是.length不用每次都去计算这点好,其它的请楼下讲讲
c742435
2014-01-30 15:37:06 +08:00
真的好。访问0比访问Things.length快多了。第一种只访问了一次,第二种循环几次就放问了几次。
但是,现在这个时代,再加上会问出这种问题的你所在的编程环境,我觉得真没必要抠这点效率。
我一般都会写第二种,实在觉得慢,就加一个临时变量缓存下length的值。
bcxx
2014-01-30 15:37:26 +08:00
dom 元素 collection 的时候每个 length 都要重新遍历容器的……
czheo
2014-01-30 15:40:01 +08:00
第一种只有初始化var i= Things.length的时候读取Things.length。
第二种每跑一个循环都有要做i < Things.length的判断,每次都要读取Things.length,效率略低一点。
估计是这个区别。
c742435
2014-01-30 15:40:08 +08:00
还有,我个人会用for each 以及 for each in。
其实就是老子高兴用哪个用哪个啦。
xxr3376
2014-01-30 16:02:25 +08:00
我觉得楼主可能会喜欢这个:http://jsperf.com/fors-vs-while/10 ,js中各种循环方式的测速。
Crossin
2014-01-30 16:57:22 +08:00
除去不用每次调用.length外(其实这个的实际影响应该很小吧)
在某些情况下,比如Things是个链表,而你要在循环过程中删除Things中的部分元素,从小到大就会出错,而从大到小不会
rannnn
2014-01-30 17:12:51 +08:00
其实编译器应该吧第二种的length优化到外面去
alexrezit
2014-01-30 17:51:55 +08:00
@qiukun
速度差很多.
zhujinliang
2014-01-30 17:53:50 +08:00
这要是在c语言上又会牵扯出等于0判断与等于某值判断速度快慢,volatile关键字,乃至编译器优化的问题
alexrezit
2014-01-30 18:02:12 +08:00
@rannnn
Naive. What if array got modified in loop?
reusFork
2014-01-30 18:03:30 +08:00
@rannnn 除非编译器能确定length不会变,否则不可能做这样的优化
Narcissu5
2014-01-30 18:12:23 +08:00
犀牛书里面有讲过这个问题,实际上数组的长度是由最后一个不为undefined的元素位置决定的,所以:

1、计算length很低效,别忘了这是循环,效率差异会被放大
2、遍历的过程中,数组的长度是可能变化的。估计解释器不会在这里优化。
dorentus
2014-01-30 18:21:18 +08:00
我更喜欢这样:
for (var i = 0, n = things.length; i < n; ...
alexrezit
2014-01-30 20:08:50 +08:00
@dorentus
Caching length 有个问题就是如果 array 可能在 loop 中 length 改变就不适用了.
zythum
2014-01-30 20:14:20 +08:00
其实 Things.length 是取length这个属性的get方法。这个方法是需要耗时的。
luikore
2014-01-30 21:30:29 +08:00
换在二十年前是会快
lsylsy2
2014-01-30 22:09:18 +08:00
第一反应是Cache DRAM的机制……
抬头一看JavaScript……那应该是Length的判断机制更重要
1423
2014-01-31 01:24:08 +08:00
http://jsperf.com/fors-vs-while/77
效率最高的竟然是会破坏数据的 pop 和 shift!
有比较了解的能讲一下吗?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/98700

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX