var j = 0;
for(var i=0;i<100;i++){
j = j++;
}
console.log(j);
今天偶然遇到了这样的一个问题,求j的最终值等于多少。我的第一反应就是j=100,答案真的是100吗?错误。
按照我的理解,在第一次循环里面,j=j++;右边的j先赋值给左边的j,此时j为0。赋值完毕后,j再自增1,此时j应该为1。以此类推100次循环后j为100。可我为什么在控制台打印出来j最终等于0呢。
我怀疑理解了这么久的自增是不是理解错了。于是查阅相关资料,发现自增原来是这样的。
就拿第一次循环来举例吧,j=j++;先新建一个临时变量,如temp,把右边j的值给temp,此时temp为0;然后右边的j自增,此时的j变为1;j++是一个表达式,是有返回值的,返回值就是temp,最终把temp返回给左边的j,所以第一次循环j最终为0,以此类推,不管循环多少次,j永远为0。
把此过程写成一个方法更好理解:
function makeAdd(args){
var temp = args;
args = args+1;
return temp;
}
因此j=j++可以看做:
j = makeAdd(j);
当然,上述的方法仅仅是方便理解,在实际中是行不通的。因为在js里面基本类型是按值传递的(需详细了解可以看我上一篇博客),需要写成按引用传递的对象。
var obj = {};
obj.x = 0;
var makeAdd = function (o) {
var temp = o.x;
o.x = o.x + 1;
return temp;
};
for (var i = 0; i < 100; i++) {
obj.x = makeAdd(obj);
}
console.log(obj.x);