引用类型和基本类型的区别?

556 阅读2分钟

两者的区别可以主要从以下三个方面说起:

1:内存空间 2:对值的操作 3:变量的赋值

《javascript高级程序设计》中对于二者的定义是:基本类型值指的是简单的数据段,而引用类型值指那些可能由多个值构成的对象。

基本数据类型包括 string  number  boolean  symbol  undefined 

引用类型包括:array  object  function

1:内存空间

我们将js的内存分为栈内存和堆内存;基本类型存放于栈内存中,包括变量以及变量的值。

例如:

var name = 'dayao';
var city = 'beijing';
var age = 22; 

引用类型是大小不固定的数据,但是他们的地址大小是固定的,所以把地址存在栈中而值存在堆中。

var person1 = {name:'dayao'};
var person2 = {name:'xiaoming'};
var person3 = {name:'xiaohong'};

2:对值的操作

基本类型值:按值访问,操作的是他们实际保存的值

引用类型:按引用访问,当查询时我们需要从栈中读取内存地址,然后再找到保存再堆内存中的值。对于引用类型的值,我们可以给其添加属性和方法,也可以改变和删除其属性的方法。

3:变量的赋值

基本类型变量的复制:从一个变量向另一个赋值时,会在栈中创建一个新值,然后把值复制到为新变量分配的位置上。

引用类型变量的复制:赋值的是存储在栈中的指针,将指针复制到栈中为新变量分配的空间中,而这个指针副本和原指针指向存储在堆中的同一个对象,复制操作结束后,两个变量实际上将引用同一个对象,因此改变其中一个,将影响另一个。