美文网首页
1.1堆和栈

1.1堆和栈

作者: 请叫我小飞鹅 | 来源:发表于2017-03-10 17:30 被阅读0次

1.栈(stack)和堆(heap)

stack:自动分配和释放的内存空间。

栈使用的是[一级缓存], 他们通常都是被调用时处于存储空间中,调用完毕立即释放

heap:动态分配的内存,大小不定,系统不会自动释放。

堆则是存放在[二级缓存]中,生命周期由虚拟机的垃圾回收来决定(并不是一旦成为孤儿对象就能被回收)。所以调用这些对象的速度要相对来得低一些

2.基本类型和引用类型:

基本类型:存放在栈内存中的简单数据段,大小确定,内存空间大小可以分配。

5种基本类型:Undefined,Null,Boolean,Number,String。

基本类型是按值存放的,所以可以直接访问

引用类型:存放在堆内存中的对象。

与其他语言不同,Javascript不允许直接访问内存中的位置,也就是说不能直接操作对象的内存空间。在操作对象时,实际上是在操作对象的引用而不是实际的对象。为此,引用类型是按引用访问的。

变量实际保存的是一个指针,指针则指向存放在堆内存中的对象。每个空间大小不一,要根据情况进行特定分配。

当我们需要访问引用类型(如对象,数组,函数等)的值时,首先从栈中获得该对象的地址指针,然后再从堆内存中取得所需的数据。

3.为什么会有栈内存和堆内存之分

通常与垃圾回收机制有关。为了使程序运行时占用的内存最小。

当一个方法执行时,每个方法都会建立自己的内存栈,在这个方法内定的变量将会逐个放入这块栈内存里,随着方法的执行结束,这个方法的内存栈也将自然销毁了。因此所有方法中定义的变量都是存放在占内存中的。

当我们在程序中创建一个对象时,这个对象将被保存堆内存中,以便重复利用(因为对象的创建成本通常较大)。堆内存中的对象不会碎放的结束而销毁,即使方法结束后,这个对象还可能被另一个引用变量所引用(方法的参数传递时很常见),则这个对象依然不会被销毁,只有当一个对象没有任何引用变量引用它时,系统的垃圾回收机制才会在合适的时候回收他。

传送门:垃圾回收机制[]

相关文章

  • Stack(栈)-Swift实现与斐波那契数列的应用

    定义 仅可以在尾端(栈顶)进行插入和删除的线性表,称为栈。 特点 栈拥有栈底和栈顶,只许在栈顶就行插入和删除操作,...

  • 基于数组的栈

    第一,初始化栈和清空栈。 第二,入栈和出栈。 第三,获取栈顶元素和显示栈中元素。 第四,调用方法。 这就是基于数组...

  • 基于链表的栈

    第一,初始化栈和清空栈。 第二,入栈和出栈。 第三,获取栈顶元素和显示栈中元素。 第四,调用方法。 这就是基于链表...

  • 数据结构——栈和队列

    用数组实现栈和队列 用栈实现队列 用队列实现栈 栈和队列的经典算法题最小间距栈宠物收养所 数组实现栈和队列 用数组...

  • 堆和栈,队列和栈

    堆和栈的区别 1、堆栈空间分配 栈(操作系统):由操作系统自动分配释放 ,存放函数的参数值,局部变量的值等。其操作...

  • OpenGL_矩阵压栈和出栈

    1. 压栈和出栈的理解 压栈出栈操作的是矩阵 用来记录矩阵的状态 压栈PushMatrix和出栈PopMatrix...

  • 栈(两栈共享空间结构)

    栈:限定只能在表尾进行插入和删除的线性表。 两栈共享空间结构:使用数组同时实现两个栈,即栈1和栈2;栈1为空时,栈...

  • 栈和队列算法设计题(二)

    题目 假设以I和O分别表示入栈和出栈操作。栈的初态和终态均为空,入栈和出栈的操作顺序可表示为仅由I和O组成的序列,...

  • 2. 进程栈和线程栈

    Linux 中的各种栈:进程栈 线程栈 内核栈 中断栈 - 木易博客专栏 - CSDN博客 栈的作用:函数调用和多...

  • 单调栈 2020-06-12(未经允许,禁止转载)

    1.单调栈 指栈内元素保持单调性的栈结构,分为单调增栈(栈底到栈顶元素递增)和单调减栈(栈底到栈顶元素递减) 2....

网友评论

      本文标题:1.1堆和栈

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