浅拷贝和深拷贝

时间:2022-02-10 22:37:03

堆(heap)和栈(stack)区别:

堆和栈都是内存中的一部分,有着不同的作用,而且一个程序需要在这片区域上分配内存。

栈内存:栈内存首先是一片内存区域,存储的都是局部变量,凡是定义在方法中的都是局部变量(方法外的是全局变量),for循环内部定义的也是局部变量,是先加载函数才能进行局部变量的定义,所以方法先进栈,然后再定义变量,变量有自己的作用域,一旦离开作用域,变量就会被释放。栈内存的更新速度很快,因为局部变量的生命周期都很短。(先进后出)

堆内存:存储的是数组和对象(其实数组就是对象),凡是new建立的都是在堆中,堆中存放的都是实体(对象),实体用于封装数据,而且是封装多个(实体的多个属性),如果一个数据消失,这个实体也没有消失,还可以用,所以堆是不会随时释放的,但是栈不一样,栈里存放的都是单个变量,变量被释放了,那就没有了。堆里的实体虽然不会被释放,但是会被当成垃圾,Java有垃圾回收机制不定时的收取。(先进先出)

原始类型(基本类型)

包括 数字、字符串、布尔值、null、undefined 。
存储在栈(stack)中的简单字段,它们的值直接存储在变量访问的位置。

对象(引用)类型
包括数组、函数、对象。
存储在堆中的对象。也就是存储在变量处的值是一个指针,指向存储对象的内存处。

基本类型与引用类型最大的区别实际就是传值与传址的区别

值传递:基本类型采用的是值传递

址传递:引用类型则是地址传递,将存放在栈内存中的地址赋值给接收的变量

引用类型怎么比较是否相等呢?

比如两个单独的对象或数组必须比较它们的属性或元素:

例:

   function (a,b)

   {

     if(a.length != b.length)

       return false; //两个长度不同的数组不相等

   for(var i = 0; i<a.length; i++)
    {   if(a[i] != b[i])
      return false;    }   
return true;   }

浅复制:就是将一个对象的内存地址的“”编号“”复制给另一个对象。对于原始类型如number类型,浅拷贝是对值的复制,对于引用类型来如对象来说,浅拷贝是对对象地址的复制(浅复制的所有对象都可以修改这个内存地址的数据)

深复制:先新建一个空对象,内存中新开辟一块地址,把被复制对象的所有的属性方法一一复制过来,复制变量值,对于非基本类型的变量,则递归至基本类型变量后,再复制。

深复制:1,新开辟内存地址,2,递归来刨根复制