草庐IT

垃圾箱

全部标签

javascript - 使用 Javascript 的垃圾收集关闭规则

我有一个程序使用Javascript作为脚本语言绑定(bind)到一个更大的C++应用程序。我交替使用V8和webkit,但底层运行时对于这个问题应该无关紧要。在这个应用程序中,我动态创建的对象会收到回调。我将像这样创建这个回调绑定(bind)...functionf(){varobj=CreateNewCallbackObj();obj.onCallback=dowork;//doworkisafunction}显然这会产生GC问题,因为obj已经超出范围并且最终将被删除。我想要的是让对象自行管理其生命周期。该对象最终会收到一个回调,表示其生命周期结束,当发生这种情况时,它可以自行删

javascript - ES6 全局符号是否被垃圾收集?

ES6符号的无上限动态创建是否会导致不可恢复的内存使用?在Erlang(以及以前的Ruby)中,原子/符号的创建不会被垃圾收集。似乎在全局符号注册表(Symbol.for('string'))中创建的符号无法被垃圾收集并保持全局唯一性,但我可能遗漏了一些东西。在我看来,这似乎不是由ES6规范规定的。 最佳答案 符号是原语并不意味着它们不能使用引用和分配来实现。想想js中的原始字符串。浏览器可能会以这种方式实现符号,使它们受gc的约束。在chrome中快速测试for(;;)Symbol();(不要运行它)会导致锯齿状内存配置文件,因此

javascript - 垃圾收集未使用的模块

我正在使用动态导入来加载用户在浏览器中编写的脚本。我首先将脚本内容放入一个blob中,然后使用动态import()将脚本作为模块加载。随着时间的推移,我预计这些脚本会发生变化并被销毁,从而使相应的模块被垃圾回收。然而,根据Chrome中的内存分析,这并没有发生。原因似乎与称为ModuleMap的东西有关。这是我在不再使用所有脚本后拍摄的内存快照的屏幕截图。如您所见,Window对象提供了通往这些模块的保留路径。只要是这种情况,我肯定最终会耗尽内存,因为每次用户编辑脚本时都会创建这些模块。我想知道是否有办法让Chrome(和其他浏览器)在不再使用这些模块时卸载它们。

javascript - 如何释放和垃圾收集 WebGL 上下文?

我正在为Web和移动设备开发WebGL应用程序。我经常使用硬刷新来测试我的WebGL实现的结果。View尝试后,出现错误:Error:WebGL:Exceeded16liveWebGLcontextsforthisprincipal,losingtheleastrecentlyusedone.这不会出现在新启动的浏览器上,而是在多次刷新网站后出现。我猜WebGL上下文没有正确完成、释放、销毁、清理、释放。我该怎么做?KhronosGroup在此处创建了一个用于释放和垃圾收集WebGL上下文的测试套件:https://www.khronos.org/registry/webgl/sdk/

javascript - 分配一个新的字符串值会产生需要收集的垃圾吗?

考虑这个javascript代码:vars="Somestring";s="Morestring";垃圾收集器(GC)在这种操作之后是否还有工作要做?(我想知道在尝试最小化GC暂停时是否应该担心分配字符串文字。)e:让我觉得有点好笑的是,虽然我在问题中明确指出我需要尽量减少GC,但每个人都认为我错了。如果真的必须知道特定的细节:我有一个javascript游戏——它在Chrome中运行良好,但在Firefox中有半频繁的暂停,这似乎是由于GC。(我什至检查过Firefox的MemChaser扩展,暂停与垃圾收集完全一致。) 最佳答案

javascript - Node.js 的垃圾收集器

我从这个线程中学到了garbagecollectionwithnode.jsnode.js使用分代GC。我经常使用循环对象引用(我删除/确保最终超出范围)并且想知道node.js是否能很好地处理它们。所以例如。如果它是使用ref完成的。计数,会有问题,所以我想知道Node在这方面有多好。一些使用场景:对于每个http请求,我都创建了一个带有lambda的setTimeout,它可能引用了范围对象。scope对象也有对timeout对象的引用等...对于每个用户session,我都有一个指向http请求对象的指针(仍在进行C编程)引用,它也引用了session对象等...请求对象经常被删

javascript - 如何在 Javascript 中收集匿名对象垃圾?

如果我创建了一个对象但没有将它赋值给任何东西,Javascript什么时候会垃圾回收这个对象?这是一个例子:alert(newDate().getTime());如果不进行这样的垃圾回收,会不会造成内存泄漏?for(vari=0;i 最佳答案 如果作用域内没有人引用匿名对象,则下次GC运行时将对它们进行垃圾回收。因此,在Console.info完成运行后,它们就可以进行垃圾收集了。如果您设置任何范围内的变量来引用它们,那么它们就不会。 关于javascript-如何在Javascript

javascript - QML 垃圾收集删除仍在使用的对象

我曾多次遇到过这个问题,对象是动态创建的,无论它们是用QML还是C++创建的。对象在仍在使用时被删除,导致无缘无故的硬崩溃。这些对象一直被引用并成为其他对象的父对象,一直到根对象,所以我发现QML在它们的引用计数仍然高于零时删除这些对象很奇怪。到目前为止,我找到的唯一解决方案是在C++中创建对象并将所有权显式设置为CPP,从而无法从QML中删除对象。起初我认为这可能是育儿问题,因为我使用的是QObject派生类,动态实例化的QML方法传递一个Item对于parent,而QtObject甚至不带有父属性-它没有从QObject公开.但后来我尝试使用Qobject派生它公开并使用育儿,最后

javascript - 浏览器刷新不进行垃圾回收

我在所有经过测试的浏览器上都发现了这一点——Windows上的IE、Firefox、Chrome和Safari以及Apple上的Safari。据称,浏览器刷新、后退按钮或前进链接应该转储浏览器节点和javascript变量和对象等。WebGL似乎不是这种情况。我第一次注意到它是在开发一个需要大约100MB到200MB内存的复杂WebGL应用程序时。在开发过程中,我必须进行大量刷新,而我的计算机会在5-10次刷新后开始变慢并死机。经过一些研究,我意识到这不应该。内存泄漏的公认解决方案是刷新页面,这应该释放所有javascript对象和变量以及dom节点。但是看看下面的图片:那么这里有什么

javascript - V8 不会清理所有垃圾

我在清理V8中的垃圾时遇到问题。首先,我的Javascript如下:varbigstring="ASD";for(varb=0;b在C++中,我正在运行一个循环:调用框架。收集垃圾:while(!V8::IdleNotification()){};预期的结果是每次迭代都会收集junkArray垃圾。毕竟,IdleNotification仅在“V8已完成尽可能多的清理工作”时才返回true(doc).事实上,垃圾只被清理*大约。每100次迭代。我错过了一步吗?junkArray由于某种原因不是frame之后的垃圾吗?*通过比较前后堆使用情况确定 最佳答案