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/7093565


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM