ext内存泄露分析1

来源:互联网 发布:淘宝天天特价报名 编辑:程序博客网 时间:2024/06/10 10:09

内存释放在使用Ext开发OPOA系统时显得尤为重要
开始接触Ext开发,中间花了很多时间来解决内存泄漏。
最开始Ext还是3.0版,泄漏得一塌胡涂,也没什么处理头绪,只知道在onDestroy里加delete语句,用sIEve看效果。
而Ext3.1有了一个很大的进步,基本上绝大多数组件都没有泄漏了。但并不意味着Ext没泄漏,做出的页面也没泄漏。JS是自动回收的,而只要有一个引用没有释放就可能导致一大片JS对象及Dom节点无法释放,所以迟早还是会面对这个问题。

一、泄漏的分类
1. 组件创建后未销毁(Ext层面)
这里说的组件一般是指继承自Ext.Component的,它在创建时会注册到Ext.ComponentMgr中,不调用destroy方法是不会从中移除的,所以它永远不会被释放。
大部分组件是放置于Container中,Container销毁会将子组件一起销毁,是不存在这个问题。但当它是Ext.Window(没有父容器)或手工render的组件(例如用模板画html,再render到指定Dom节点)时,如果不主动销毁问题就发生了。

2. 组件自身有泄漏或使用不当(JS&Dom层面)
目前Ext原生组件的泄漏已经很少了,但自己扩展的组件不注意的话会造成浏览器无法释放的泄漏。
而使用不当是指破坏了组件内部结构,导致无法完全释放。

3. JS对象泄漏(JS层面)
JS是有自动回收机制,但它也只会回收你用不到的对象(或者说你已经不可能访问到的对象)
所以,如果在一个长时间运行的JS代码中,你创建了很多属性或对象,并且一直保存着它们的引用,也会使内存增长。
正确的做法是,不用的属性就要delete掉,不用的对象也要解除引用。(delete引用的属性或置变量为null)

原创粉丝点击