您的位置:首页 > Web前端 > JavaScript

JS传参时值传递与引用传递的区别

2020-03-29 13:25 561 查看

基本类型&引用类型

基本类型(值类型):undefind、null、boolean、number、string;
引用类型:在逻辑上等价于其他程序语言的类;如:Array、Object、Function、Date…

本质区别

1.基本类型的变量保存变量值本身,而引用类型的变量保存变量所在内存地址;
2.基本类型的变量在内存中占用的存储空间固定,即,在栈内开辟一块以变量名命名的固定存储空间;而引用类型需要栈和堆共同协作,在栈内开辟一块以变量命名的存储空间,该空间内存放指针(堆内存的地址),堆内存放数据。
3.基本类型变量间的赋值时传递栈内数据;引用类型对象间的赋值时传递栈内指向的堆地址;
代码演示:
值类型传递:

<script type="text/javascript">
var num1=666;
var num2=num1;
console.log(num1);//666
console.log(num2);//666
num1=999;
console.log(num1);//999
console.log(num2);//666
</script>

引用类型传递:

<script type="text/javascript">
var obj1={};
obj1.num=666;
var obj2=obj1;
console.log(obj1.num);//666
console.log(obj2.num);//666

obj2.num=999;

console.log(obj1.num);//999
console.log(obj2.num);//999
</script>

总结一下:值类型传递参数时不同的变量占用的栈空间不同,但栈空间内的数据相同;引用类型传递参数时不同的变量占用的栈空间不同,但是栈空间指向的堆空间是同一个。即,值类型传参:你变我不变;引用类型传参:大家一起变。

  • 点赞
  • 收藏
  • 分享
  • 文章举报
wanguo_S 发布了6 篇原创文章 · 获赞 0 · 访问量 99 私信 关注
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: