基本数据类型和引用数据类型的存储区别?

目录

1、存储位置的区别

2、变量赋值时的区别

① 基本数据类型

② 引用数据类型

3、小结

① 声明变量时不同的内存地址分配

② 不同的类型数据导致赋值变量时的不同


1、存储位置的区别

基本数据类型和引用数据类型存储在内存中的位置不同:

① 基本数据类型存储在栈中        ② 引用类型的对象存储于堆中

2、变量赋值时的区别

当我们把变量赋值给一个变量时,解析器首先要确认的就是这个值是基本类型值还是引用类型值。

① 基本数据类型

基本类型数据是存放在栈中

let a = 10;
let b = a; // 赋值操作
b = 20;
console.log(a); // 10值

a的值为一个基本类型,是存储在栈中,将a的值赋给b虽然两个变量的值相等,但是两个变量保存了两个不同的内存地址。

下图演示了基本类型赋值的过程:

基本数据类型和引用数据类型的存储区别?_第1张图片

② 引用数据类型

引用类型数据存放在堆中,每个堆内存对象都有对应的引用地址指向它,引用地址存放在栈中

var obj1 = {}
var obj2 = obj1;
obj2.name = "小草莓";
console.log(obj1.name); // 小草莓

obj1是一个引用类型,在赋值操作过程中,实际是将堆内存对象在栈内存的引用地址复制了一份给了obj2,实际上他们共同指向了同一个堆内存对象,所以更改obj2会对obj1产生影响。

下图演示这个引用类型赋值过程:

基本数据类型和引用数据类型的存储区别?_第2张图片

3、小结

① 声明变量时不同的内存地址分配

简单类型对应的值存储在栈中,在栈中存放的是对应的值;

引用类型对应的值存储在堆中,在栈中存放的是指向堆内存的地址;

② 不同的类型数据导致赋值变量时的不同

简单类型赋值,是生成相同的值,两个变量对应不同的地址;

复杂类型赋值,是将保存对象的内存地址赋值给另一个变量。也就是两个变量指向堆内存中同一个对象;

你可能感兴趣的:(每日专栏,JavaScript,javascript,前端)