JavaScript中函数参数按值传递与引用传递的本质区别
JavaScript函数参数统一按值传递基本类型传值副本修改不影响外部引用类型传地址副本可修改对象内容但无法改变原变量指向。JavaScript 中函数参数既不是纯粹的“按值传递”也不是纯粹的“按引用传递”而是统一按值传递但这个“值”可能是基本类型的值也可能是引用类型的地址值。理解这一点是厘清所谓“值传递 vs 引用传递”混淆的关键。基本类型传的是实实在在的值当参数是 number、string、boolean、null、undefined、symbol、bigint 这些基本类型时传入函数的是该值的一个**完全独立的副本**。函数内部对参数的修改不会影响外部变量。说明这些类型在内存中直接存储值位于栈stack中。 例子 let x 42;function change(n) { n 100; }change(x);console.log(x); // 输出 42 —— 没变 引用类型传的是指向对象的地址值即“指针副本”当参数是 object、array、function、date、regexp、map、set 等引用类型时传入函数的是该对象在堆heap中的**内存地址的一个副本**。这个副本本身是按值传递的地址值被复制但它仍指向同一个对象。说明你无法通过参数改变外部变量“指向谁”但可以修改它“所指向的对象的内容”。 例子 let obj { a: 1 };function modify(o) { o.a 99; } // ? 修改对象属性 → 外部可见modify(obj);console.log(obj.a); // 输出 99function reassign(o) { o {}; } // ? 重新赋值参数 → 只改了副本不影响外部reassign(obj);console.log(obj.a); // 仍是 99 关键区别不在“类型”而在“能否改变绑定关系”真正决定行为的是函数内是否执行了 对形参的重新赋值操作 RedClaw 百度推出的手机端万能AI Agent助手
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2524904.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!