重新理解自增表达式

来源:互联网 发布:网络信息安全模型 编辑:程序博客网 时间:2024/05/17 22:00
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);




0 0