• 技术文章 >web前端 >js教程

    秒懂js的垃圾回收机制

    hzchzc2020-06-13 09:49:41转载701
    前言


    js具有自动垃圾回收机制,换句话说,执行环境会管理代码执行过程中使用的内存。

    js垃圾回收的原理


    执行环境会找出那些不再继续使用的变量,然后释放其占用的内存。

    js垃圾回收的策略


    标记清除

    当变量进入环境时,就将这个变量标记为“进入环境”,而当变量离开环境时,则将其标记为“离开环境”。

    标记变量方式看具体的实现,比如可以使用一个“进入环境”的变量列表和一个“离开环境”的变量列表来跟踪哪个变量发生了变化。

    使用过标记清除的浏览器有IE,Firefox,chrome。

    引用计数

    这是一种不太常见的垃圾回收的策略,它就是跟踪每一个值被引用的次数。

    当声明了一个变量a并将一个引用类型值({name:'cc'})赋给该变量时,则这个值的引用次数就是1,如果a({name:'cc'})又赋给另一个变量b,则该值的引用次数加1。反之,如果a赋值{name:'xx'},则{name:'cc'}这个值的引用次数减1。当{name:'cc'}这个值的引用的次数变为0时,则说明没有办法再访问{name:'cc'}这个值了,因而可以将其占用的内存空间回收。这样,当垃圾回收器工作的时候,{name:'cc'}这个值占用的内存空间就会被回收。

    这种方式曾今被Netscape Navigator 3.0使用过,但是有一个严重问题:循环引用。

    function circleReferenceProbem(){
      let objectA = new Object()
      let objectB = new Object()
    
      objectA.someOtherObject = objectB
      objectB.anotherObject = objectA
    }

    执行这个函数后,因为这两个引用值的引用次数永远不会为0,垃圾回收器永远不会回收它们占用的内存空间。

    js垃圾回收器的性能


    因为js垃圾回收器是每隔一个周期就执行一次垃圾回收。

    如果为变量分配的内存数量不大的话,那么垃圾回收器的回收工作量就不大。但是,当垃圾回收器的工作量过大的时候,就很可能会出现卡顿的情况。

    js中管理内存的建议


    谢谢阅读!

    需要加微信交流,可留言!

    推荐教程:《JS教程

    以上就是秒懂js的垃圾回收机制的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:掘金社区,如有侵犯,请联系admin@php.cn删除
    专题推荐:js
    上一篇:Vue 轻量级图表组件 下一篇:在 Vue 中使用分页
    大前端线上培训班

    相关文章推荐

    • 如何理解javascript中的函数概念• JavaScript 和 Dart 的区别• JavaScript常用的数组方法• php+javascript实现用户注册模块(附源码)

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网