JavaScript的垃圾回收机制

简介: JavaScript的垃圾回收机制

 

JavaScript语言是一门优秀的脚本语言。其中包含脚本语言的灵活性外还拥有许多高级语言的特性。例如充许构建和实例化一个对象,垃圾回收机制(GC:Garbage Collecation)。通常我们使用new创建对象,GC负责回收对象占用内存区域。因此了解GC,可以加深对javascript垃圾回收机制的理解。

GC在回收内存时,首先会判断该对象是否被其它对象引用。在确定没有其它对象引用便释放该对象内存区域。因此如何确定对象不再被引用是GC的关键所在。

<script type="text/javascript">
function aa()
{
    this.rr = "弹窗";    
}
function bb()
{
    this.rr = "弹窗";
}
var b1;
function cc()
{
    var a1 = new aa();
    b1 = new bb();
    return b1;
}
cc();
alert(b1.rr)
</script>

如上代码中,执行完cc()后a1被回收了,此后我们可以通过b1.rr弹出文字窗口。在一些基础书籍中解释为:a1为局部变量,b1是全局变量。局部变量执行完后会被GC回收.但不全是这样,如下代码:

<script type="text/javascript">
function aa()
{
    this.rr = "弹窗";    
}
function bb()
{
    this.rr = "弹窗";
}
function cc()
{
    var a1 = new aa();
    var b1 = new bb();
    return b1;
}
var b1 = cc();
alert(b1.rr);
</script>

此时cc函数中的 a1,b1都是局部变量,但仍然会弹出文字窗口。说明b1并没有被GC回收。因此javascript中局部变量不是所有时候都被GC回收的。

GC回收机制还需要近一步了解。在此时引入几个概念:双向链表,作用域链,活动对象(为了方便理解,简化了原文的概念[http://softbbs。pconline。com。cn/9497825。html]) , 其中双向链表描述复杂对象的上下层级关系。 作用域链与活动对象分别是双向链表中的某个节点。以函数cc为例变量层级关系为:

window<=>cc<=>a1<=>rr

<=>b1<=>rr

在执行cc()方法时,内存中变量的引用关系如上图,文字解释如下:

   cc的活动对象包括a1和b1,其作用域链是window

   cc的活动对象包括a1和b1,其作用域链是window

   a1的活动对象包括rr,其作用域链是cc

   b1的活动对象包括rr,其作用域链是cc

执行cc()时,cc的执行环境会创建一个活动对象和一个作用域链。其局部变量a1,b1都会挂在cc的活动对象中。当cc()执行完毕后,执行环境会尝试回收活动对象占用的内存。但因局部变量b1 通过return b1,为其增加了一条作用域链:window<=>b1<=>rr,所以GC停止对b1回收。因此如果想将一个局部变量/函数提升为全局的,为其增加一条作用域链就OK了。

同时控制好对象的作用域链也变得重要了。因作用域链会意外导致GC无法回收目标对象。例如:

<SCRIPT LANGUAGE="JavaScript">
<!--
//猫
function cat(name)
{
    var zhuren ;
    this.name = name;
        
    //设置主人
    this.addZhuRen = function(zr){
        zhuren = zr;
    }
    this.getZhuRen = function(){
        return zhuren;
    }
}
    
//主人
function zhuren(name){
    this.name = name;
}
//创建主人:
var zr = new zhuren("zhangsan");
//创建猫
var cat1 = new cat("asan");
//设置该猫的主人
cat1.addZhuRen(zr);
//释放主人
zr = null ;
//此处还存在对主人对象的引用
alert(cat1.getZhuRen().name)
//-->
</SCRIPT>
目录
相关文章
|
1月前
|
JavaScript 前端开发 Java
JavaScript基础知识-垃圾回收
关于JavaScript垃圾回收基础知识的介绍。
29 1
JavaScript基础知识-垃圾回收
|
2月前
|
前端开发 JavaScript Java
揭开 JavaScript 垃圾回收的秘密——一场与内存泄漏的生死较量,让你的代码从此焕然一新!
【8月更文挑战第23天】本文通过多个实例深入探讨了JavaScript中的垃圾回收机制及其对应用性能的影响。首先介绍了基本的内存管理方式,随后分析了变量不再使用时的回收过程。接着,通过事件监听器未被移除及全局变量管理不当等场景展示了常见的内存泄漏问题。最后,文章介绍了使用`WeakRef`和`FinalizationRegistry`等现代API来有效避免内存泄漏的方法。理解并运用这些技术能显著提升Web应用的稳定性和效率。
77 0
|
4月前
|
JavaScript 前端开发 算法
【JavaScript】JavaScript 垃圾回收机制深度解析:内存管理的艺术
JavaScript的内存管理和垃圾回收机制涉及栈内存与堆内存、引用计数与标记-清除算法。栈内存存储基本类型和函数调用时的局部变量,而堆内存用于复杂数据类型,如对象和数组。垃圾回收主要通过标记-清除策略,处理不再被引用的对象。现代引擎如V8使用分代收集和增量标记等优化方法,减少停顿并提升性能。开发者应注意避免内存泄漏,如及时解除引用、管理DOM引用和定时器,使用WeakMap和WeakSet等。理解这些原理和最佳实践对于编写高效代码至关重要。
91 5
|
3月前
|
存储 JavaScript 算法
你真的了解JS垃圾回收机制吗?
你真的了解JS垃圾回收机制吗?
24 0
|
3月前
|
自然语言处理 前端开发 JavaScript
前端 JS 经典:闭包与内存泄漏、垃圾回收
前端 JS 经典:闭包与内存泄漏、垃圾回收
32 0
|
4月前
|
JavaScript 前端开发 算法
JavaScript 使用自动垃圾回收机制来管理内存
JavaScript 使用自动垃圾回收机制来管理内存
28 0
|
4月前
|
JavaScript 前端开发 算法
JavaScript的垃圾回收机制
JavaScript的垃圾回收机制
23 0
|
4月前
|
JavaScript 前端开发 算法
JS垃圾回收机制
JS垃圾回收机制
|
5月前
|
JavaScript 前端开发 算法
垃圾回收:JavaScript内存管理的利器
垃圾回收:JavaScript内存管理的利器
|
5月前
|
JavaScript 前端开发 算法
JavaScript的垃圾回收机制通过标记-清除算法自动管理内存
【5月更文挑战第11天】JavaScript的垃圾回收机制通过标记-清除算法自动管理内存,免除开发者处理内存泄漏问题。它从根对象开始遍历,标记活动对象,未标记的对象被视为垃圾并释放内存。优化技术包括分代收集和增量收集,以提升性能。然而,开发者仍需谨慎处理全局变量、闭包、定时器和DOM引用,防止内存泄漏,保证程序稳定性和性能。
48 0