for循环中++i和i++的区别

语法

for (语句1; 语句2; 语句3) { 被执行的代码块 } for (语句1; 语句2; 语句3) { 被执行的代码块 }

语句 1 在循环(代码块)开始前执行浏览器

语句 2 定义运行循环(代码块)的条件性能

语句 3 在循环(代码块)已被执行以后执行(这就是循环中的++i和i++结果同样的缘由,可是性能不同,稍后解释)code

语句1 (同上面语法中的 语句1)

语句1 是可选的,也就是说不使用语句1 也能够。内存

var i=2,len=5; for (; i<len; i++){ document.write(cars[i] + "<br>"); } var i=2,len=5; for (; i<len; i++){ document.write(cars[i] + "<br>"); }

也能够在语句1 中初始化任意(或者多个)值:it

var arr = [1,2,3] for (var i=0,len=arr.length; i<len; i++){ document.write(cars[i] + "<br>"); } var arr = [1,2,3] for (var i=0,len=arr.length; i<len; i++){ document.write(cars[i] + "<br>"); }

语句2 (同上)

一般语句 2 用于评估初始变量的条件。console

语句 2 一样是可选的。for循环

若是语句 2 返回 true,则循环再次开始,若是返回 false,则循环将结束。class

若是您省略了语句 2,那么必须在循环内提供 break。不然循环就没法停下来。这样有可能令浏览器崩溃变量

语句3 (同上)

一般语句 3 会增长初始变量的值。循环

语句 3 也是可选的。

语句 3 有多种用法。增量能够是负数 (i--),或者更大 (i=i+15)。

语句 3 也能够省略(好比当循环内部有相应的代码时):

var i=0,len=arr.length; for (; i<len; ){ document.write(cars[i] + "<br>"); i++; } var i=0,len=arr.length; for (; i<len; ){ document.write(cars[i] + "<br>"); i++; }

++i 和 i++ 的区别

 var i = 10; console.log(i++); //10 ,先引用原值,而后加1 等价于: var i= 10; console.log(i); //先输出i i++; //而后加1 var i = 10; console.log(++i); //11 , 此次是先加1,而后输出 var i = 10; console.log(i++); //10 ,先引用原值,而后加1 等价于: var i= 10; console.log(i); //先输出i i++; //而后加1 var i = 10; console.log(++i); //11 , 此次是先加1,而后输出

总结下:++在前下自加后运算;++在后先运算后自加

for循环中++i 和 i++ 的区别

根据上面的for循环的语法定义 ++i 和 i++的结果是同样的,都要等代码块执行完毕才能执行语句3,可是性能是不一样的。在大量数据的时候++i的性能要比i++的性能好缘由:

i++因为是在使用当前值以后再+1,因此须要一个临时的变量来转存。

而++i则是在直接+1,省去了对内存的操做的环节,相对而言可以提升性能

相关文章
相关标签/搜索