手动管理需要开发者自己管理内存,什么时候申请内存空间,什么时候释放都需要小心处理,否则容易形成内存泄漏和指针乱飞的局面。C 语言开发是典型的需要手动管理内存的例子。
自动管理通常通过垃圾回收的机制来实现内存管理。NodeJS 中的内存管理是自动管理的。
垃圾回收
====
垃圾回收器(garbage collector,GC)通过判断对象是否还在被其他对象引用来决定是否回收该对象的内存空间。
垃圾回收之前的内存
=========
在下面的图中,有一些对象还在被其他对象使用,而有一些对象已经是完全孤立状态,没有其他对象使用它了。这些已经完全孤立状态的对象是可以被垃圾回收器回收的。
垃圾回收之后的内存
=========
垃圾回收一旦开始运行,内存中的那些完全孤立(不可到达)的对象会被删除,内存空间会被释放。
垃圾回收是如何工作的
==========
要搞清楚垃圾回收是如何工作的,需要先了解一些基本概念。
基本概念
====
-
常驻集大小(resident set size):NodeJS 进程运行时占据的内存大小,通常包含:代码、栈和堆。
-
栈(stack):包含原始类型数据和指向对象的引用数据。栈中保存着局部变量和指向堆上对象的指针或定义应用程序控制流的指针(比如函数调用等)。下面代码中,a 和 b 都保存在栈中。function add (a, b) { return a + b } add(4, 5)
-
堆(heap):存放引用类型数据,比如对象、字符串、闭包等。下面代码中,创建的 Car 对象会被保存在堆中。function Car (opts) { this.name = opts.name } const LightningMcQueen = new Car({name: ‘Lightning McQueen’}) 对象创建后,堆内存状态如下:现在我们添加更多的对象:const SallyCarrera = new Car({name: ‘Sally Carrera’}) const Mater = new Car({name: ‘Mater’}) 堆内存状态如下:如果现在执行垃圾回收,没有任何内存会被释放,因为每个对象都在被使用(可到达)。现在我们修改代码,如下:function Engine (power) { this.power = power } function Car (opts) { this.name = opts.name this.engine = new Engine(opts.power) } let LightningMcQueen = new Car({name: ‘Lightning McQueen’, power: 900}) let SallyCarrera = new Car({name: ‘Sally Carrera’, power: 500}) let Mater = new Car({name: ‘Mater’, power: 100}) 堆内存状态变成:如果我们不在使用 Mater 的话,通过 Mater = undefined 删除了对内存中对象的引用,则内存状态变化为:此时内存中的 Mater 不再被其他对象使用了(不可达),当垃圾回收运行的时候,Mater 对象会被回收,其占据的内存会被释放。
-
对象的浅层大小(shallow size of an object):对象本身占据的内存大小。
-
对象的保留大小(retained size of an object):删除对象及其依赖对象后释放的内存大小
垃圾回收器是如何工作的
===========
NodeJS 的垃圾回收通过 V8 实现。大多数对象的生命周期都很短,而少数对象的寿命往往更长。为了利用这种行为,V8 将堆分成两个部分,年轻代(Young Generation)和老年代(Old Generation)。
年轻代
===
新的内存需求都在年轻代中分配。年轻代的大小很小,在 1 到 8 MB 之间。在年轻代中内存分配非常便宜,V8 在内存中会逐个为对象分配空间,当到达年轻代的边界时,会触发一次垃圾回收。
V8 在年轻代会采用 Scavenge 回收策略。Scavenge 采用复制的方式进行垃圾回收。它将内存一分为二,每一部分空间称为 semispace。这两个空间,只有一个空间处于使用中,另一个则处于闲置。使用中的 semispace 称为 「From 空间」,闲置的 semispace 称为 「To 空间」。
年轻代的内存分配过程如下:
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)
![](https://img-blog.csdnimg.cn/img_convert/548dbb92b490b2470b39d2e1da240142.jpeg)
最后
你要问前端开发难不难,我就得说计算机领域里常说的一句话,这句话就是『难的不会,会的不难』,对于不熟悉某领域技术的人来说,因为不了解所以产生神秘感,神秘感就会让人感觉很难,也就是『难的不会』;当学会这项技术之后,知道什么什么技术能做到什么做不到,只是做起来花多少时间的问题而已,没啥难的,所以就是『会的不难』。
我特地针对初学者整理一套前端学习资料,免费分享给大家,戳这里即可免费领取
我特地针对初学者整理一套前端学习资料,免费分享给大家,戳这里即可免费领取
[外链图片转存中…(img-Zx9kGPVG-1712367466298)]