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、不会立即回收垃圾对象

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

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

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

(0)
上一篇 2022年6月21日 下午11:36
下一篇 2022年6月21日 下午11:46


相关推荐

  • 2020 CSP-S第二轮认证一等奖获奖名单

    2020 CSP-S第二轮认证一等奖获奖名单CCFCSP J S2020 第二轮提高级一等名单证书编号 省份 准考证号 姓名 性别 总分 学校 年级 CCF CSP JS2020 00001 安徽 AH 00120 洪朝阳 男 365 合肥市第一中学 高二 CCF CSP JS2020 00002 安徽 AH 00451 杨珖 男 355 安徽师范大学附属中学 高二 CCF CSP JS2020 00003 安徽 AH 00098 葛子越 男 340 安徽师范大学附属中学 高一 CCF CSP JS2020 00004 安徽 AH 00549 朱剑

    2026年3月17日
    2
  • QFile 总结

    QFile 总结voidQFile::flush()[虚]刷新文件缓存到磁盘。close()也刷新文件缓存。

    2022年6月1日
    55
  • MATLAB 极坐标绘图、坐标系转换

    MATLAB 极坐标绘图、坐标系转换极坐标绘图函数 polar 格式 polar theta rho LineSpec theta 与 X 轴正半轴的夹角 为弧度 rho 与原点的距离角度转换函数格式 弧度 degtorad 角度 将角度从度数转换为弧度极坐标转化为直角坐标格式 x y pol2cart theta rho x y z pol2cart theta rho z x rho

    2026年3月17日
    2
  • 记录mybatis分页查询失败[通俗易懂]

    记录mybatis分页查询失败[通俗易懂]在进行mybatis的分页查询时出现ExceptionInIntializerError错误代码信息如下在检查mapper和插件配置后,试着换了一下mybatis的版本后原版本替换后版本成功的进行了分页查询

    2022年6月2日
    50
  • 几种电平转换电路

    几种电平转换电路在电路设计时 有时会遇到电压域不匹配的问题 如芯片为 1 8V 供电 而 MCU 为 3 3V 供电 这时候就需要进行电平转换才能通讯 今天就来介绍几种常用的电平转换电路 二 三极管单向电平转换一些通

    2026年3月26日
    2
  • 【科普】显示器VGA、DVI、HDMI、DP等各种接口详细科普

    由于显示器接口十分众多,比如说VGA、DVI、HDMI、DP等等等等,而每个接口都有各种型号,很容易让小白绕晕,因此这里详细介绍一下各个接口以及接口的相关型号参数。

    2022年4月9日
    72

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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