JavaScript性能优化-GC算法篇[通俗易懂]

JavaScript性能优化-GC算法篇[通俗易懂]GC算法简介1、GC是一种机制,垃圾回收器完成具体的工作2、工作的内容就是查找垃圾释放空间、回收空间3、算法就是工作时查找和回收所遵循的规则常见的GC算法1、引用计数2、标记清除3、标记整理4、分代回收GC算法之引用计数算法1、核心思想:设置引用数,判断当前引用数是否为02、引用计数器3、引用关系发生改变时改变引用数字4、引用数字为0是立即回收代码演示如下constuser1={age:10};constuser2={age:20};con.

大家好,又见面了,我是你们的朋友全栈君。

在这里插入图片描述

GC算法简介
1、GC是一种机制,垃圾回收器完成具体的工作
2、工作的内容就是查找垃圾释放空间、回收空间
3、算法就是工作时查找和回收所遵循的规则
常见的GC算法
1、引用计数
2、标记清除
3、标记整理
4、分代回收
GC算法之引用计数算法
1、核心思想:设置引用数,判断当前引用数是否为0
2、引用计数器
3、引用关系发生改变时改变引用数字
4、引用数字为0是立即回收

代码演示如下

const user1 = { age: 10 };
const user2 = { age: 20 };
const user3 = { age: 30 };

const nameList = [user1.age, user2.age, user3.age];

function fn() {

    num1 = 10
    
    num2 = 20
    
}

fn()

function fn2() {

    const num1 = 10
    
    const num2 = 20
    
}
fn2()

//在这个全局作用域下 user1 user2 user3 nameList num1 num2

//上面的引用计数都不是0 所以不会被回收

//改造一下

function fn2() {

    const num1 = 10
    
    const num2 = 20
}

fn2() //一旦这行代码执行 也就意味着在全局作用域下找不到num1 和num2

//这个时候num1 和num2 引用计数都是0 这个计数器都会工作 

//把num1和num2占用的空间进行回收
GC算法之引用计数算法优点和缺点
优点:

1、发现垃圾立即回收

2、最大限度减少程序暂停

缺点:

1、无法回收循环引用的对象

function fun3() {

    const obj1 = {}
    
    const obj2 = {}
    
    obj1.name = obj2
    
    obj2.name = obj1
}

fun3()

//虽然在全局作用域下看不到了obj1和obj2 
//但是在内部还存在着引用所以 obj1和obj2的引用计数不是0

2、时间开销大

时刻要维护引用计数导致等待时间较长
GC算法之引用标记清除算法实现原理
1、核心思想:分标记和清除两个阶段完成

2、遍历所有对象找标记活动对象

3、遍历所有对象清除没有标记对象

4、回收相应的空间

总的来说就是两个步骤 

第一步遍历所有可达对象 如果对象还有子属性的话进行递归操作继续遍历
遍历完成后就行标记

第二步找到没有标记的对象进行清除
GC算法之标记清除算法优点和缺点
优点:弥补了引用计数算法的不足,引用计数算法的缺点也可以是看到标记清除算法的优点

缺点:
1、标记-清除算法的比较大的缺点就是垃圾收集后有可能会造成大量的内存碎片
2、不会立即回收垃圾对象
GC算法之标记整理算法实现原理
1、标记整理算法可以看做是标记清除的增强
2、标记阶段的操作和标记清除一致
3、清除阶段先会执行整理,移动对象位置,把分散的对象整合到一起
GC算法之标记整理算法优点和缺点
1、减少碎片空间化
2、不会立即回收垃圾对象

谢谢观看,如有不足,敬请指教

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/151614.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • windows下thrift的使用(python)

    windows下thrift的使用(python)

    2021年11月19日
  • java 软件运维面试题_运维面试题(一)

    java 软件运维面试题_运维面试题(一)一基础知识1什么是linux的daemon进程?和一般进程有什么区别?daemon进程又称为守护进程,是在系统启动就运行,系统关闭才停止的进程,独立于终端之外,不与客户端交互。一般进程在关闭终端后就停止了,而daemon进程不会停止。2通过free命令查看内存是,看到的buffer和cache各表示什么含义?Buffer的核心作用是用来缓冲,缓和冲击。比如你每秒要写100次硬盘,对系统冲…

  • iOS逆向入门实践 — 逆向微信,伪装定位(二)

    iOS逆向入门实践 — 逆向微信,伪装定位(二)1.创建工程还是跟之前的步骤一致,创建工程,然后配置Makefile。注意创建工程时名字只能包含数字跟字母。Makefile上面引入的 FakeWeChatLocationManager.m 文件是主要代码实现的地方,分离出来好模块化。2.Reveal注入为了更好地定位代码,需要分析一下“附近的人”这个界面对应的类名是什么,然后进一步分析

  • Django(47)drf请求生命周期分析

    Django(47)drf请求生命周期分析前言一般我们写完序列化以后,我们就会开始写视图了,drf中我们一般使用CBV的方式,也就是类视图的方式,最基础的我们会使用fromrest_framework.viewsimportAPIVi

  • java设计模式3,里氏替换原则

    java设计模式3,里氏替换原则里氏替换原则的内容可以描述为:“派生类(子类)对象可以在程序中代替其基类(超类)对象。”

    2022年10月29日
  • 用心做软件—细节决定成败「建议收藏」

    用心做软件—细节决定成败「建议收藏」软件是什么?也许在编程者的眼中这是自己智慧的结晶,是技术运用的成果。但是在用户的眼中呢,用户会在乎你到底用了多少高级的技术、用了什么前卫的技术吗?我想大部分用户是不会管的,无论你是C#做的,Java做的,C++还是C做的,你的系统是Windows还是Linux,android还是塞班。用户的眼中你的软件只是一件产品,那么既然是产品,就要有价值,要能为用户带来方便,能为用户解决问题。当今的互联网上,

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号