javascript 内存回收机制理解


Posted in Javascript onJanuary 17, 2011

1.唠叨
javascript语言是一门优秀的脚本语言.其中包含脚本语言的灵活性外还拥有许多高级语言的特性.例如充许构建和实例化一个对象,垃圾回收机制(GC:Garbage Collecation).通常我们使用new创建对象,GC负责回收对象占用内存区域.因此了解GC,可以加深对javascript垃圾回收机制的理解。
2.用局部变量和全局变量解释GC
GC在回收内存时,首先会判断该对象是否被其它对象引用.在确定没有其它对象引用便释放该对象内存区域.因此如何确定对象不再被引用是GC的关键所在.

<script> 
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> 
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回收的.
3.抽象理解GC
GC回收机制还需要近一步了解。在此时引入几个概念:双向链表,作用域链,活动对象(为了方便理解,简化了原文的概念[http://softbbs.pconline.com.cn/9497825.html]) , 其中双向链表描述复杂对象的上下层级关系. 作用域链与活动对象分别是双向链表中的某个节点.以函数cc为例变量层级关系为:
window<=>cc<=>a1<=>rr
<=>b1<=>rr
(原文有详细解释)在执行cc()方法时,内存中变量的引用关系如上图,文字解释如下:
window的活动对象包括cc,假设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>
Javascript 相关文章推荐
六款帮助你实现惊艳视差滚动效果的jQuery插件
Sep 14 Javascript
thinkphp中常用的系统常量和系统变量
Mar 05 Javascript
JavaScript实现单击下拉框选择直接跳转页面的方法
Jul 02 Javascript
基于jQuery实现交互体验社会化分享代码附源码下载
Jan 04 Javascript
Markdown+Bootstrap图片自适应属性详解
May 21 Javascript
Vue.js系列之项目搭建(1)
Jan 03 Javascript
js脚本编写简单刷票投票系统
Jun 27 Javascript
浅谈JS对象添加getter与setter的5种方法
Jun 09 Javascript
浅谈微信小程序之官方UI框架we-ui使用教程
Aug 20 Javascript
微信小程序之裁剪图片成圆形的实现代码
Oct 11 Javascript
koa-router路由参数和前端路由的结合详解
May 19 Javascript
Vue实现手机号、验证码登录(60s禁用倒计时)
Dec 19 Vue.js
javascript 延迟加载技术(lazyload)简单实现
Jan 17 #Javascript
关于COOKIE个数与大小的问题
Jan 17 #Javascript
js实现的跟随鼠标移动的时钟效果(中英文日期显示)
Jan 17 #Javascript
Jquery 插件开发笔记整理
Jan 17 #Javascript
JQuery学习笔记 nt-child的使用
Jan 17 #Javascript
Jquery知识点三 jquery表单对象操作
Jan 17 #Javascript
基于jquery的返回顶部效果(兼容IE6)
Jan 17 #Javascript
You might like
分享下页面关键字抓取components.arrow.com站点代码
2014/01/30 PHP
php中多维数组按指定value排序的实现代码
2014/08/19 PHP
PHP文件上传判断file是否己选择上传文件的方法
2014/11/10 PHP
Laravel实现用户注册和登录
2015/01/23 PHP
关于WordPress的SEO优化相关的一些PHP页面脚本技巧
2015/12/10 PHP
javascript 页面只自动刷新一次
2009/07/10 Javascript
jQuery阻止同类型事件小结
2013/04/19 Javascript
javascript中数组的sort()方法的使用介绍
2013/12/18 Javascript
js获得当前时区夏令时发生和终止的时间代码
2014/02/23 Javascript
javascript实现unicode与ASCII相互转换的方法
2015/12/10 Javascript
BootstrapTable请求数据时设置超时(timeout)的方法
2017/01/22 Javascript
jQuery插件zTree实现删除树节点的方法示例
2017/03/08 Javascript
JavaScript定义及输出螺旋矩阵的方法详解
2017/12/01 Javascript
详解js的作用域、预解析机制
2018/02/05 Javascript
node.js实现简单的压缩/解压缩功能示例
2019/11/05 Javascript
JavaScript监听一个DOM元素大小变化
2020/04/26 Javascript
node中短信api实现验证码登录的示例代码
2021/01/20 Javascript
Python之PyUnit单元测试实例
2014/10/11 Python
Python中的lstrip()方法使用简介
2015/05/19 Python
python机器学习实战之最近邻kNN分类器
2017/12/20 Python
使用APScheduler3.0.1 实现定时任务的方法
2019/07/22 Python
Python中类似于jquery的pyquery库用法分析
2019/12/02 Python
python默认参数调用方法解析
2020/02/09 Python
python代码中怎么换行
2020/06/17 Python
Python远程方法调用实现过程解析
2020/07/28 Python
Python如何绘制日历图和热力图
2020/08/07 Python
python爬取招聘要求等信息实例
2020/11/20 Python
Python实现简单猜数字游戏
2021/02/03 Python
CSS3 text shadow字体阴影效果
2016/01/08 HTML / CSS
Html5 audio标签样式的修改
2016/01/28 HTML / CSS
汽车技术服务与营销专业在籍生自荐信
2013/09/28 职场文书
2014年中学生检讨书大全
2014/10/09 职场文书
英语投诉信范文
2015/07/03 职场文书
德能勤绩工作总结
2015/08/11 职场文书
运动会广播稿100字
2015/08/19 职场文书
PyTorch 如何检查模型梯度是否可导
2021/06/05 Python