JavaScript的垃圾回收机制,清除无用变量,释放多余内存,展现更好的性能

简介: 本篇文章将讲解一下javascript的垃圾回收机制。同时,我们必须先具备作用域链的概念,不懂的小伙伴可以先花3分钟观看一下这篇文章,简单了解一下作用域链的知识——从零开始讲解JavaScript中作用域链的概念及用途

01

垃圾回收机制


在JavaScript中,具有自动垃圾回收机制,也就是说执行环境会自动负责管理代码执行过程中的内存使用情况,会自动清除一些没有用的变量,以此来释放内存。该机制每隔一段时间会执行一次。


例如下面这段代码,函数 change 在执行时,声明了一个局部变量my_color,然后等函数执行完毕以后,这个局部变量也没有作用了,所以这时垃圾回收机制就会将这个没用的的局部变量my_color给清除掉。


    let color = 'red'
    function change() {  let my_color = 'blue'  color = 'green'}
    change()


    JavaScript中能实现这样的垃圾回收的功能的一共有两种方式: 标记清除引用计数


    02

    标记清除


    标记清除是JavaScript中最常用的垃圾回收方式。它的实现方式是这样的,当代码执行在一个环境中时,每声明一个变量,就会对该变量做一个标记,例如标记一个进入执行环境;当代码执行进入另一个环境中时,也就是说要离开上一个环境,这时对上一个环境中的变量做一个标记,例如标记一个离开执行环境,等到垃圾回收执行时,会根据标记来决定要清除哪些变量。



    03

    引用计数


    引用计数是一种不太常用的垃圾回收方式。顾名思义,就是针对值为引用类型数据的变量进行计数,那么我们先来看一下以下这个例子,来理解一下这个方式的实现方式


      let color = [1, 2, 3]
      function change() {  let new_color = [4, 5, 6]  color = new_color}
      change()
      console.log(color)  //返回  [4, 5, 6]


      这个例子中的函数change内部声明了一个变量new_color,并将一个引用类型值赋值给它,同时又将变量new_color赋值给了全局变量color,那么这种情况下,这个局部变量new_color就不会被当成垃圾回收了,因为此时的变量new_color并不是一个无用的局部变量了,它被全局变量color所引用了。


      那么为什么变量new_color不会被当成垃圾回收呢?其实引用计数的垃圾回收方式是这样的,当声明一个变量时,会给该变量设定一个值为0的引用次数,当该变量被别的变量所引用,就将引用次数+1,若取消了原本的引用,则引用次数-1,而垃圾回收机制就是判断一个变量的值的引用数是否为0,如果为0,就被当成无用变量给回收掉,如果不为0,则不对该变量做任何的处理。



      04

      管理内存


      有时我们需要手动管理一下内存的分配和清除,应该很好理解,如果有更大的内存空间,因为可以给更多的变量分配内存,就会提高代码运行的效率,增加线程中能够执行的代码语句的数量。


      所以我们要确保占用更少的内存使得页面获得更好的性能,就可以只将需要用到的数据保存到变量中,一旦数据不再使用,我们可以通过给变量赋值null来释放数据的引用,这种方法就叫做解除引用。这种方法大多数是用于全局变量,因为局部变量一般在离开环境以后就会被自动清除。


      我们来改变一下上面这个例子,使得变量new_color被引用完后,当成无用变量给清除掉。


        let color = [1, 2, 3]
        function change() {  let new_color = [4, 5, 6]  color = new_color}
        change()
        console.log(color)  //返回  [4, 5, 6]
        color = null


        在这个例子中,函数change内部声明的变量new_color被全局变量color所引用,所以此时变量new_color的引用次数为1,我们为了让变量new_color被清除,所以在代码的最后一行,赋值一个null给全局变量color手动解除了变量color对变量new_color的引用,此时变量new_color的引用次数-1,所以啊当前它的引用次数为0了。当垃圾回收机制执行的时候,发现它的引用次数为0,就把该变量当成无用变量给清除了,释放了内存。



        05

        结束语


        理解了js的垃圾回收机制,我们才能修改代码对性能进行优化 。好了,JavaScript的垃圾回收机制的讲解就讲到这里,希望对大家有所帮助。


        相关文章
        |
        6天前
        |
        存储 缓存 算法
        操作系统的内存管理机制及其对系统性能的影响
        本文深入探讨了操作系统中内存管理的关键技术和策略,以及它们如何影响计算机系统的整体性能。通过分析不同的内存分配算法、虚拟内存技术、以及缓存策略,本文旨在揭示这些机制对于提高资源利用效率、减少延迟和优化用户体验的重要性。结合最新的研究成果和实际案例,本文为读者提供了对操作系统内存管理深度理解的视角,并讨论了未来可能的发展趋势。
        |
        5天前
        |
        存储 JavaScript 前端开发
        |
        18小时前
        |
        存储 缓存 Java
        解决Java中的内存优化与垃圾回收机制
        解决Java中的内存优化与垃圾回收机制
        |
        3天前
        |
        存储 JavaScript 前端开发
        js【详解】数据类型原理(含变量赋值详解-浅拷贝)
        js【详解】数据类型原理(含变量赋值详解-浅拷贝)
        8 0
        |
        3天前
        |
        JavaScript
        JS字符串数据类型转换,字符串如何转成变量,+号只要有一个是字符串,就会把另外一个转成字符串,- * / 都会把数据转成数字类型,数字型控制台是蓝色,字符型控制台是黑色,
        JS字符串数据类型转换,字符串如何转成变量,+号只要有一个是字符串,就会把另外一个转成字符串,- * / 都会把数据转成数字类型,数字型控制台是蓝色,字符型控制台是黑色,
        |
        5天前
        |
        缓存 算法 UED
        操作系统中的内存管理技术及其性能影响
        在现代计算机系统中,操作系统的内存管理机制对系统性能有着至关重要的影响。本文将深入探讨内存管理的关键技术,包括虚拟内存、分页和分段,以及它们如何影响系统的响应速度和资源利用效率。通过分析不同内存管理策略的性能表现,并结合最新的研究成果,本文旨在为读者提供关于优化内存管理以提高系统性能的实用指导。
        |
        5天前
        |
        存储 JavaScript 算法
        你真的了解JS垃圾回收机制吗?
        你真的了解JS垃圾回收机制吗?
        |
        5天前
        |
        存储 JavaScript 前端开发
        面试官:JS中变量定义时内存有什么变化?
        面试官:JS中变量定义时内存有什么变化?
        |
        5天前
        |
        前端开发 JavaScript
        前端 JS 经典:变量交换
        前端 JS 经典:变量交换
        7 0
        |
        6天前
        |
        Java 程序员 C++
        C++和Python在内存分配、释放以及垃圾回收机制上有何不同?
        【7月更文挑战第2天】C++和Python在内存分配、释放以及垃圾回收机制上有何不同?
        10 0