JS基本类型和引用类型赋值的区别

时间:2022-09-24 15:45:42

基本类型包括:number,string,boolean,null,undefined
引用类型包括:Object,Array,Date,RegExp,Function
通过代码来看他们的区别:
var a=2;
var b=a;
b=3;
console.log(a);//2
console.log(b);//3

首先基本类型的赋值是不可改变的,上面的是基本类型的赋值,我们可以看出b的赋值并没有覆盖a的值,第二句b=a,在这里b只是一个指向a的指针,指针的指向可以改变,所以b=3改变了指针的指向,也就是我们所认识的改变,事实上是指针的指向改变了,基本数据类型存放在栈中,当使用a的值来初始化b时,b中也保存了2,但是b中的2和a中的2是完全独立的,b中的值只是a中的一个副本,所以这两个变量可以参与任何操作而不会互相影响。
var aa=[3,4,2,5];
var bb=aa;
bb.push(6);
console.log(aa);//34256
console.log(bb);//34256
上面是引用类型的赋值,这个赋值是可以改变的,引用类型的存储需要在内存的栈区和堆区共同完成,栈区保存变量标识符和指向堆内存的地址,上面的bb=aa赋值实际上是一个指针的赋值,这个指针存储了指向存储在堆内存的一个对象,那么赋值操作后,两个变量都保存了同一个对象地址么人这两个地址指向了同一个对象,因此改变了其中任何一个变量都会互相影响。