我正在开发一个创建和删除大量 DOM 的应用程序。我注意到浏览器选项卡中的进程内存不断增加,尽管 javascript 堆内存保持不变。在测试应用程序中,我从父 div 创建和删除 div。
<button onclick="createStuff()">Create</button>
<button onclick="deleteStuff()">Delete</button>
<div id="parent"></div>
function createStuff() {
var parentDiv = document.getElementById('parent');
for (var i = 0; i < 50000; i++) {
var child = document.createElement('div');
child.id = i;
child.textContent = i;
parentDiv.appendChild(child);
child = null;
}
parentDiv = null;
}
function deleteStuff() {
var parentDiv = document.getElementById('parent');
for (var i = 0; i < 50000; i++) {
var child = document.getElementById(i);
parentDiv.removeChild(child);
child = null;
}
parentDiv = null;
}
我已经确认 javascript 堆没有通过 chrome 开发工具泄漏(我是新手,所以我可能错过了一些东西)。但是,该过程的内存继续增加。从我读过的所有内容来看,我怀疑删除的 dom 仍在 dom 堆中。
其他帖子还说浏览器最终会释放分配给已删除 dom 的内存。在上面的 jsfiddle 示例中,我多次点击创建和删除。我的 javascript 堆稳定在 4.9MB。我的进程内存高达 115MB。我已经等了 30 分钟了,它一点也没有下降。
问题
感谢您的帮助!
编辑
我已经使用了 chrome 开发工具,javascript 堆没有增长。有趣的是,堆快照之间唯一发生变化的是一个(数组)对象。据我了解,括号中的任何内容都由浏览器控制并且超出我的范围。每个后续的 create->delete 都会删除旧的(数组)对象并在删除过程中创建一个新对象。
在时间轴上我可以看到 javascript 堆是常量并且节点被清理了,但是即使在节点数下降之后,用 (shift + esc) 显示的内存也不会下降。
似乎我正在尽我所能确保清理我的 javascript 堆,但 dom 清理超出我的范围并且独立于 javascript GC。这种说法正确吗?
被移除的doms是否属于新生代堆?有没有办法对此堆大小设置限制?我重复测试,直到达到 500MB,但仍然没有清理。我正在使用 Chrome 35.0.1916.114 顺便说一下。
最佳答案
我知道您问过有关 Chrome 的问题,但我将描述它在 Firefox 中的工作原理,希望您和其他读者可能会对它感兴趣。 Chrome 可能会以类似的方式工作,我不确定。
对于您的测试用例,Firefox 内存使用量不会持续增加。只有在您第一次创建/删除元素时,内存使用量才会永久增加。 在随后的创建/删除周期中,所有分配的内存随后都会被回收。
至少在 Firefox 中,您不能在不重新加载页面的情况下强制释放此内存。如果您真的需要临时分配这么多内存,您应该在 iframe 中执行此操作,完成后可以丢弃。
技术细节如下:
在 Firefox 中,有一个名为 about:memory 的工具可以检查内存使用情况。 .它按类别分解已用内存,并具有强制清理内存(GC/CC/最小化内存)的控件。
下面是 about:memory 的相关部分在您创建/删除 DOM 元素后以及 GC 启动后的样子:
├──34.34 MB (03.30%) -- window(http://fiddle.jshell.net/PSxPz/2/show/)
│ ├──26.54 MB (02.55%) -- layout
│ │ ├──13.95 MB (01.34%) -- (8 tiny)
│ │ │ ├───7.63 MB (00.73%) ── line-boxes
│ │ │ ├───4.00 MB (00.38%) ── pres-contexts
│ │ │ ├───2.26 MB (00.22%) ── pres-shell
│ │ │ ├───0.04 MB (00.00%) ── style-structs
│ │ │ ├───0.01 MB (00.00%) ── rule-nodes
│ │ │ ├───0.01 MB (00.00%) ── style-contexts
│ │ │ ├───0.00 MB (00.00%) ── style-sets
│ │ │ └───0.00 MB (00.00%) ── text-runs
│ │ └──12.59 MB (01.21%) -- frames
│ │ ├───7.25 MB (00.70%) ── nsBlockFrame
│ │ ├───5.34 MB (00.51%) ── nsTextFrame
│ │ └───0.00 MB (00.00%) ── sundries
│ └───7.80 MB (00.75%) -- (4 tiny)
│ ├──7.51 MB (00.72%) ++ dom
│ ├──0.29 MB (00.03%) ++ js-compartment(http://fiddle.jshell.net/PSxPz/2/show/)
│ ├──0.00 MB (00.00%) ── style-sheets
│ └──0.00 MB (00.00%) ── property-tables
(如果 DOM 节点已从文档中删除,但尚未被垃圾回收,它们将显示在 orphan-nodes 测量下。)
大部分额外内存(在创建 DOM 节点时请求)保留用于布局。
此行为 is基于显示现实生活中的网页在其生命周期中通常需要大约相同数量的布局对象的测量:一个典型的网页不会分配 10,000 个框架只是为了销毁它们并显示一个非常简单的页面,比如这里的测试用例。
这种内存管理行为在提高帧分配/解除分配速度方面得到返回,减少了 memory fragmentation ,并避免在销毁框架后访问框架时出现严重的安全错误。
关于javascript - DOM 何时从内存中移除?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23926550/
作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代
ruby如何管理内存。例如:如果我们在执行过程中采用C程序,则以下是内存模型。类似于这个ruby如何处理内存。C:__________________|||stack|||------------------||||------------------|||||Heap|||||__________________|||data|__________________|text|__________________Ruby:? 最佳答案 Ruby中没有“内存”这样的东西。Class#allocate分配一个对象并返回该对象。这就是程序
我几天前在我的rubyonrails2.3.2上安装了Sphinx和Thinking-Sphinx,基本搜索效果很好。这意味着,没有任何条件。现在,我想用一些条件过滤搜索。我有公告模型,索引如下所示:define_indexdoindexestitle,:as=>:title,:sortable=>trueindexesdescription,:as=>:description,:sortable=>trueend也许我错了,但我注意到只有当我将:sortable=>true语法添加到这些属性时,我才能将它们用作搜索条件。否则它找不到任何东西。现在,我还在使用acts_as_tag
你好,我无法成功如何在散列中删除key后释放内存。当我从哈希中删除键时,内存不会释放,也不会在手动调用GC.start后释放。当从Hash中删除键并且这些对象在某处泄漏时,这是预期的行为还是GC不释放内存?如何在Ruby中删除Hash中的键并在内存中取消分配它?例子:irb(main):001:0>`ps-orss=-p#{Process.pid}`.to_i=>4748irb(main):002:0>a={}=>{}irb(main):003:0>1000000.times{|i|a[i]="test#{i}"}=>1000000irb(main):004:0>`ps-orss=-p
我遇到了一个非常奇怪的问题,我很难解决。在我看来,我有一个与data-remote="true"和data-method="delete"的链接。当我单击该链接时,我可以看到对我的Rails服务器的DELETE请求。返回的JS代码会更改此链接的属性,其中包括href和data-method。再次单击此链接后,我的服务器收到了对新href的请求,但使用的是旧的data-method,即使我已将其从DELETE到POST(它仍然发送一个DELETE请求)。但是,如果我刷新页面,HTML与"new"HTML相同(随返回的JS发生变化),但它实际上发送了正确的请求类型。这就是这个问题令我困惑的
这会导致Ruby出现内存问题吗?我知道如果大小超过10KB,Open-URI会写入TempFile。但是HTTParty会在写入TempFile之前尝试将整个PDF保存到内存吗?src=Tempfile.new("file.pdf")src.binmodesrc.writeHTTParty.get("large_file.pdf").parsed_response 最佳答案 您可以使用Net::HTTP。参见thedocumentation(特别是标题为“流媒体响应机构”的部分)。这是文档中的示例:uri=URI('http://e
我有这个:AccountSummary我想单击该链接,但在使用link_to时出现错误。我试过:bot.click(page.link_with(:href=>/menu_home/))bot.click(page.link_with(:class=>'top_level_active'))bot.click(page.link_with(:href=>/AccountSummary/))我得到的错误是:NoMethodError:nil:NilClass的未定义方法“[]” 最佳答案 那是一个javascript链接。Mechan
我看到有关未找到文件min.map的错误消息:GETjQuery'sjquery-1.10.2.min.mapistriggeringa404(NotFound)截图这是从哪里来的? 最佳答案 如果ChromeDevTools报告.map文件的404(可能是jquery-1.10.2.min.map、jquery.min.map或jquery-2.0.3.min.map,但任何事情都可能发生)首先要知道的是,这仅在使用DevTools时才会请求。您的用户不会遇到此404。现在您可以修复此问题或禁用sourcemap功能。修复:获取文
在部署在heroku上的Rails应用程序(v:3.1)中,我在内存中获得了更多具有相同ID的对象。我的heroku控制台日志:>>Project.find_all_by_id(92).size=>2>>ActiveRecord::Base.connection.execute('select*fromprojectswhereid=92').to_a.size=>1这怎么可能?可能是什么问题? 最佳答案 解决方案根据您的SQL查询,您的数据库中显然没有重复条目。也许您的类项目中的size或length方法已被覆盖。我试过find_
我的两个不同的Rails应用程序的内存有一些奇怪的问题。这两个应用程序都使用rails3.0.7。每个Controller请求分配20-30-50MB的内存。在生产模式下,这个数量减少到5-10。但这是同样的事情。这是两个应用程序使用的gem列表:gem'pg'gem'haml'gem'sass'gem'devise'gem'simple_form'gem'state_machine'gem"globalize3","0.1.0.beta"gem"easy_globalize3_accessors"gem'paperclip'gem'andand'关闭所有这些gem不会给我任何结果。我