JS 傳遞對象問題,指針引用

        $(function () {
            var test1 = function (args) {
                args.name = "lcc2";
                args = { name: "lcc3" };
            };
            var test2 = function (args) {
                args = { name: "lcc2" };
                args.name = "lcc3";
            };

        
            var params1 = { "params": "600" };
            var params2 = { "params": "600" };

            params1 = { name: "lcc1" };
            test1.call(this, params1);
            console.log(JSON.stringify(params1));

            params2 = { name: "lcc1" };
            test2(params2);
            console.log(JSON.stringify(params2));
        });

 

 若是是傳遞指針,那麼會先複製該指針,在函數內部使用的是複製後的指針,這個指針與原來的指針指向相同的地址,若是在函數內部將複製後的指針指向了另外的新的對象,那麼不會影響原有的指針;
但 是對於傳遞指針應用,若是將傳遞進來的指針指向了新的對象,那麼原始的指針也就指向了新的對象,這樣就會形成內存泄漏,由於原來指針指向的地方已經不能再 引用了,即便沒有將傳遞進來的指針指向新的對象,而是在函數結束的時候釋放了指針,那麼在函數外部就不能再使用原有的指針了,由於原來的內存已經被釋放了函數

 

 

http://blog.csdn.net/tedious/article/details/7093565this

相關文章
相關標籤/搜索