当前位置: 首页 > news >正文

javascript中栈内存与堆内存如何理解?以及如何区分?

在 JavaScript 中,内存管理是自动进行的,由 JavaScript 引擎负责。尽管如此,理解栈内存(Stack Memory)和堆内存(Heap Memory)之间的区别对于理解变量存储机制、内存分配和垃圾回收非常重要。

栈内存

栈内存是一种线性数据结构,它遵循先进后出(LIFO, Last In First Out)的原则。栈内存主要用于存储函数调用、局部变量、函数参数以及程序执行的上下文。栈内存的特点包括:

  • 快速访问:由于栈是一种简单的数据结构,访问和操作栈的速度非常快。
  • 有限大小:栈的大小是有限的,当栈空间耗尽时会发生栈溢出(stack overflow)。
  • 自动管理:栈内存中的数据通常在函数执行结束时自动释放。

在 JavaScript 中,原始数据类型(如 Number, String, Boolean, Undefined, NullSymbol)的值直接存储在栈内存中。这意味着原始类型的值是按值访问的,并且在栈内存中直接保存这些值。

let number = 10; // 原始类型的值存储在栈内存中
let string = "Hello"; // 字符串值存储在栈内存中

堆内存

堆内存是一大片内存空间,它不像栈内存那样有序。堆内存主要用于存储对象(如数组、函数、类的实例等)。堆内存的特点包括:

  • 动态分配:堆内存可以按需申请空间,并且访问速度比栈内存慢。
  • 手动管理:在一些低级语言中,堆内存需要程序员手动管理。但在 JavaScript 中,垃圾回收机制自动管理堆内存。
  • 持久性:堆内存中的数据可以长时间存在,直到垃圾回收机制判定其不再使用时才会被释放。

在 JavaScript 中,对象的引用存储在栈内存中,而对象本身的数据存储在堆内存中。这意味着,当你声明一个对象时,栈内存中会保存一个指向堆内存中对象的指针。

let object = { name: "Alice" }; // 对象的引用存储在栈内存中,对象本身存储在堆内存中

如何区分

  • 原始类型 vs 对象类型:原始类型的值直接存储在栈内存中,而对象类型的引用存储在栈内存中,对象本身的数据存储在堆内存中。
  • 存储方式:栈内存中的数据是按值存储的,堆内存中的数据是按引用存储的。
  • 生命周期:栈内存中的数据通常在函数执行结束后自动释放,而堆内存中的数据则在不再被引用时由垃圾回收机制回收。

示例

假设我们有一个简单的 JavaScript 程序,如下所示:

function example() {let a = 10;           // a 存储在栈内存中let b = { value: 20 }; // b 的引用存储在栈内存中,对象存储在堆内存中let c = "string";     // c 存储在栈内存中// 修改对象的属性会影响堆内存中的数据b.value = 30;// 函数执行结束后,a, b, c 的引用从栈内存中移除
}example();

在这个例子中,ac 是原始类型的值,直接存储在栈内存中。b 是一个对象的引用,存储在栈内存中,而对象本身存储在堆内存中。当 example 函数执行结束时,栈内存中的 a, b, c 的引用被移除,但由于 b 对象仍存在于堆内存中,直到垃圾回收机制判定其不再被任何变量引用时才会被回收。

理解栈内存和堆内存之间的区别有助于更好地管理内存资源,尤其是在处理大型对象或复杂数据结构时,这对于避免内存泄漏和优化性能至关重要。


http://www.mrgr.cn/news/30493.html

相关文章:

  • PHP:通往动态Web开发世界的桥梁
  • vue elementui el-dropdown-item设置@click无效的解决方案
  • 打假官方咨询(续)
  • 【Python】开心消消乐”简化版源码解析:用Python实现消除游戏基础逻辑
  • Vue3 : Tailwindcss之margin样式类
  • JUC学习
  • @JsonFormat 和 @DateTimeFormat 的区别
  • 将有序数组——>二叉搜索树
  • 9. 什么是 Beam Search?深入理解模型生成策略
  • Kotlin cancel CoroutineScope.launch的任务后仍运行
  • 智谱清影 -CogVideoX-2b-部署与使用,带你揭秘生成6s视频的极致体验!
  • C++初阶:STL详解(五)——vector的模拟实现
  • 华为云DevSecOps和DevOps
  • LeetCode_sql_day28(1767.寻找没有被执行的任务对)
  • Java-list集合转成前端需要的json格式
  • 【Tourism】Yuncheng(3)
  • PCL 计算点云距离
  • mp4转换成mp3,八个超简单视频转换方法
  • GUI编程18:文本框、密码框、文本域
  • 每日刷题(算法)
  • 深度学习基础案例5--VGG16人脸识别(体验学习的痛苦与乐趣)
  • OpenAl o1论文:Let’s Verify Step by Step 快速解读
  • vue2与vue3的区别
  • 论文速递!时序预测!DCSDNet:双卷积季节性分解网络,应用于天然气消费预测过程
  • 基于SSM的宿舍管理系统的设计与实现 (含源码+sql+视频导入教程+文档+PPT)
  • [vue2+axios]下载文件+文件下载为乱码