堆、栈

作者: 数据研究bot | 来源:发表于2018-10-11 00:22 被阅读5次

在了解堆和栈的概念之前,首先明确下数据类型的分类。

  • 基本数据类型:Number、String、Boolean、undefined、null
  • 引用数据类型:Object
    其中基本数据类型存放在栈中,而引用数据类型存放在堆和栈中,那么堆和栈到底有什么区别呢?先看下百度百科的解释。

堆栈空间分配
栈:由操作系统自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。
堆: 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收,分配方式倒是类似于链表。

堆栈缓存方式
栈使用的是一级缓存, 他们通常都是被调用时处于存储空间中,调用完毕立即释放。
堆则是存放在二级缓存中,生命周期由虚拟机的垃圾回收算法来决定。所以调用这些对象的速度要相对来得低一些。

堆栈数据结构区别
堆(数据结构):堆可以被看成是一棵树,如:堆排序。
栈(数据结构):一种先进后出的数据结构。


数据类型的访问模式


比如上方的代码,将a的值赋给b后,改变a的值,b并不会随之改变。
个人理解:由于基本数据类型存放在栈中,因此可以将a和b看成两个相互独立的变量,改变一个值对另一个变量并不会产生影响。而且在栈中存放的内存大小是固定的。



引用数据类型则不然,把color1的值复制给color2后,改变其中任何一个变量的属性,另一个变量都会随之改变。由于引用数据类型复制的并不是属性本身的值,而是该属性存放的地址,地址存放在栈中,属性值存放在堆中,改变变量属性实际上就是改变栈中的属性值,但是地址是不变的,而此时两个变量所指的地址相同,因此改变一个属性,另一个就会随之改变。



内存地址大小的固定的,因此可以将内存地址保存在栈内存中。 这样,当查询引用类型的变量时, 先从栈中读取内存地址, 然后再通过地址找到堆中的值。因为系统不知道需要多大内存存放数据,所以程序自己申请,这样就分配在堆里面。

相关文章

  • 10.11java中的堆和栈

    java高级-堆和栈 java堆 /栈 栈内存 / 堆内存的区别 1. java堆 /栈 2. 栈内存 / 堆内存的区别

  • 堆 栈

    “堆:堆是用来容纳应用程序动态分配的内存区域,当程序使用malloc或new分配内存时,得到的内存来自堆里。堆通常...

  • 堆、栈

    在了解堆和栈的概念之前,首先明确下数据类型的分类。 基本数据类型:Number、String、Boolean、un...

  • 栈 堆

    1、管理方式不同;对于栈来讲,是由编译器自动管理;对于堆来说,释放工作由程序员控制,容易产生内存泄漏memory ...

  • 堆 & 栈

    1.管理方式 堆,由程序员控制释放,容易产生memory leak。 栈,由编译器自动管理,无需人工控制。 2.申...

  • 堆、栈

    栈, 也叫堆栈 堆和栈的区别: 堆栈空间分配区别:1、栈(操作系统):由操作系统自动分配释放 ,存放函数的参数值,...

  • 栈 堆

  • 栈堆

    慢慢完善最近时间有点紧~一个很有意思的描述大家就简单的理解了(程序员段子):栈是吃了吐 堆是吃了拉(堆是吃了拉,先...

  • 堆&栈

    (1)栈内存用来存储局部变量和方法调用。 (2)堆内存用来存储Java中的对象。无论是成员变量,局部变量,还是类变...

  • js/jquery 学习笔记

    理解JavaScript中的堆和栈 这里先说两个概念:1、堆(heap)2、栈(stack)堆是堆内存的简称。栈是...

网友评论

      本文标题:堆、栈

      本文链接:https://www.haomeiwen.com/subject/ulcvaftx.html