web中关于垃圾回收的一些观点
感觉dom大神的解惑
关于引用计数法,注意引用的方向性就行。 A.addEventListner(B.func), 那么是增加了A对B的引用。如果A是不可回收的对象,比如全局的Stage,或者单例。那不移除就一定会导致B无法回收。如果A是可以回收的对象,那无所谓,这个引用无效。
A.addEventListner(B.func) ,对A本身没有影响。是A引用别人了,不是别人引用A。还是那句话,注意方向性。
A.addChild(B)也是同理。
倒霉的都是B
引用计数实际回收中其着重的情况很小,大部分是根节点遍历法起作用。主要就是看引用的方向性,一个对象反向追溯对它的所有引用,无法到达一个根节点就判定这个对象可以回收。根节点通常有stage,或者其他单例。也指一切确定无法回收的对象。
就是一个对象从任何方式你都再也无法访问到它,它就能被回收。
说的不是标记清除啊。v8的回收机制跟这个根节点遍历法是一个原理。拷贝整块内存到新的地方。
访问不到的全都扔掉了。
就是从几个根节点开始遍历。被根引用的全都无法回收,进入新内存区。旧区域整个删除。根本不考虑循环引用还是什么情况,只要从根无法到达就扔掉。
这篇文章也是介绍内存管理的:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Memory_Management
关于引用计数法,注意引用的方向性就行。 A.addEventListner(B.func), 那么是增加了A对B的引用。如果A是不可回收的对象,比如全局的Stage,或者单例。那不移除就一定会导致B无法回收。如果A是可以回收的对象,那无所谓,这个引用无效。
A.addEventListner(B.func) ,对A本身没有影响。是A引用别人了,不是别人引用A。还是那句话,注意方向性。
A.addChild(B)也是同理。
倒霉的都是B
引用计数实际回收中其着重的情况很小,大部分是根节点遍历法起作用。主要就是看引用的方向性,一个对象反向追溯对它的所有引用,无法到达一个根节点就判定这个对象可以回收。根节点通常有stage,或者其他单例。也指一切确定无法回收的对象。
就是一个对象从任何方式你都再也无法访问到它,它就能被回收。
说的不是标记清除啊。v8的回收机制跟这个根节点遍历法是一个原理。拷贝整块内存到新的地方。
访问不到的全都扔掉了。
就是从几个根节点开始遍历。被根引用的全都无法回收,进入新内存区。旧区域整个删除。根本不考虑循环引用还是什么情况,只要从根无法到达就扔掉。
这篇文章也是介绍内存管理的:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Memory_Management
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。
- 上一篇: Javascript 垃圾收集 IE8 内存溢出
- 下一篇: JS的垃圾回收机制和内存分配