热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JScript内存泄漏/ie内存泄漏

闭包导致了内存泄漏,至少msdn是这么说的。一直以为这是个ie6时代早已经解决的问题,从没特别留意,无意中运行了段代码才发现在ie8时代&

 

闭包导致了内存泄漏,至少msdn是这么说的。一直以为这是个ie6时代早已经解决的问题,从没特别留意,无意中运行了段代码才发现在ie8时代,这个问题还是存在的。找了点资料,了解一下。

所谓的“点资料”主要是两篇文章:

  • http://Javascript.crockford.com/memory/leak.html
  • http://www.blogjava.net/tim-wu/archive/2006/05/29/48729.html

第一篇文章是在表层进行了理解,他的例子很好。第二篇文章更深入更严格,比较抽象。

Javascript内存泄漏

按照第二篇文章提到,内存泄漏的本质就一句话:Javascript权威指南认为,因为使用计数器算法,ie只有遇到循环就注定产生泄漏。后来 eri更正说“ie6处理不了的是jscript与navite object(如dom,active object)之间的ciruclar reference“(在这种情况下才使用计数器算法)。

第一篇译言翻译在这里http://feed.yeeyan.com/articles/view/3407/10103

说得很绕口,但形象了很多:

“ 当一个DOM对象包涵有一个Javascript对象(例如一个事件处理函数)的引用,同时如果这个Javascript对象又包涵该DOM对象,那么这个循环引用就形成了。

这种结构本质上没有问题。[此时,因为该DOM对象和这个事件处理函数并没有别的引用存在,那么垃圾回收器(一种自动的内存资源管理器)本应该把它们都回收点,并内存释放。]Javascript的垃圾回收器能够检测到这种循环引用,并不会对他产生困惑。

但是不幸的是,IE DOM的内存并不能被Jscript所管理。他有他自己的内存管理系统,然而这套系统并不知道循环引用,使得一切都变得混乱。这就导致了,当循环引用形成的时候,内存释放工作不能完成。”

综上内存泄漏准确的说法是:”当碰到Closure,当我们往Native对象(例如Dom对象、ActiveX Object)上绑定事件响应代码时,一个不小心,我们就会制造出Closure Memory Leak。其关键原因,其实和前者是一样的,也是一个跨Javascript object和native object的循环引用。只是代码更为隐蔽,这个隐蔽性,是由于Javascript的语言特性造成的。但在使用类似内嵌函数的时候,内嵌的函数有拥有一个reference指向外部函数的scope,包括外部函数的参数,因此也就很容易造成一个很隐蔽的循环引用,例如: DOM_Node.onevent ->function_object.[ [ scope ] ] ->scope_chain ->Activation_object.nodeRef ->DOM_Node。“

三个例子解读

第一篇文章里的三个例子靠谱解读在这里:

http://www.javaeye.com/topic/172344

暂时我的看法

在什么情况下引起泄漏?

一般都认为是ie6才会有这个问题,但实际上在几个版本的ie里运行下面的代码会发现内存的确在增加。

/*global setTimeout */  
           
(function (limit, delay) {  
               
var queue = new Array(10);  
               
var n = 0;  
 
               
function makeSpan(n) {  
                   
var s = document.createElement('span');  
                    document
.body.appendChild(s);  
                   
var t = document.createTextNode(' ' + n);  
                    s
.appendChild(t);  
                    s
.onclick = function (e) {  
                        s
.style.backgroundColor = 'red';  
                        alert
(n);  
                   
};  
                   
return s;  
               
}  
 
               
function process(n) {  
                    queue
.push(makeSpan(n));  
                   
var s = queue.shift();  
                   
if (s) {  
                        s
.parentNode.removeChild(s);  
                   
}  
               
}  
 
               
function loop() {  
                   
if (n < limit) {  
                        process
(n);  
                        n
&#43;&#61; 1;  
                        setTimeout
(loop, delay);  
                   
}  
               
}  
 
                loop
();  
           
})(10000, 10);  

如何解决这个问题&#xff1a;一句话废话&#xff0c;删除元素之前去除附在上面的函数。&#xff08;咦&#xff0c;这句话怎么这么熟&#xff1f;&#xff09;

第二篇文章给出的解决方式看上去更和谐点。毕竟在js框架中&#xff0c;我们都会看到类似专门的回收器的代码&#xff0c;恐怕是因为对每段程序释放是太废时间的工作。

 



推荐阅读
  • 页面预渲染适用于主要包含静态内容的页面。对于依赖大量API调用的动态页面,建议采用SSR(服务器端渲染),如Nuxt等框架。更多优化策略可参见:https://github.com/HaoChuan9421/vue-cli3-optimization ... [详细]
  • 本文探讨了当通过Nginx访问网站时出现504 Gateway Timeout错误的解决方案,特别是当请求处理时间超过30秒时的情况。文章提供了调整PHP-FPM配置的具体步骤,以延长请求超时时间。 ... [详细]
  • 本文探讨了在AspNetForums平台中实施基于角色的权限控制系统的方法,旨在为不同级别的用户提供合适的访问权限,确保系统的安全性和可用性。 ... [详细]
  • 本文介绍了用户界面(User Interface, UI)的基本概念,以及在iOS应用程序中UIView及其子类的重要性和使用方式。文章详细探讨了UIView如何作为用户交互的核心组件,以及它与其他UI控件和业务逻辑的关系。 ... [详细]
  • 本文提供了一个关于AC自动机(Aho-Corasick Algorithm)的详细解析与实现方法,特别针对P3796题目进行了深入探讨。文章不仅涵盖了AC自动机的基本概念,还重点讲解了如何通过构建失败指针(fail pointer)来提高字符串匹配效率。 ... [详细]
  • 本文介绍如何使用R语言中的相关包来解析和转换搜狗细胞词库(.scel格式),并将其导出为CSV文件,以便于后续的数据分析和文本挖掘任务。 ... [详细]
  • 本文提供了一个详尽的前端开发资源列表,涵盖了从基础入门到高级应用的各个方面,包括HTML5、CSS3、JavaScript框架及库、移动开发、API接口、工具与插件等。 ... [详细]
  • 本文回顾了作者在求职阿里和腾讯实习生过程中,从最初的迷茫到最后成功获得Offer的心路历程。文中不仅分享了个人的面试经历,还提供了宝贵的面试准备建议和技巧。 ... [详细]
  • Python3爬虫入门:pyspider的基本使用[python爬虫入门]
    Python学习网有大量免费的Python入门教程,欢迎大家来学习。本文主要通过爬取去哪儿网的旅游攻略来给大家介绍pyspid ... [详细]
  • ASP.NET 进度条实现详解
    本文介绍了如何在ASP.NET中使用HTML和JavaScript创建一个动态更新的进度条,并通过Default.aspx页面进行展示。 ... [详细]
  • 本文探讨了如何在 Spring MVC 框架下,通过自定义注解和拦截器机制来实现细粒度的权限管理功能。 ... [详细]
  • 本文提供了一种有效的方法来解决当Android Studio因电脑意外重启而导致的所有import语句出现错误的问题。通过清除缓存和重建项目结构,可以快速恢复开发环境。 ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • 解析Java虚拟机HotSpot中的GC算法实现
    本文探讨了Java虚拟机(JVM)中HotSpot实现的垃圾回收(GC)算法,重点介绍了根节点枚举、安全点及安全区域的概念和技术细节,以及这些机制如何影响GC的效率和准确性。 ... [详细]
  • 贡献转移在计算每个元素的作用的时候,我们可以通过反向枚举作用效果,添加到作用元素的身上,这种方法叫做贡献转移。更正式的说, ... [详细]
author-avatar
我们每次都聊撸
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有