堆内存,所有保留的内存由noscript_shared_function_infos持有
Heap out of memory, all retained memory held by noscript_shared_function_infos
我的应用程序使用回调创建了很多函数,这是通过以下方式完成的:
v8::Local<v8::Function> myFunc = v8::Function::New(
i->GetCurrentContext(),
FunctionInvokerCallback(),
this->WrapDelegate(callbackInvoke),
0,
v8::ConstructorBehavior::kThrow,
v8::SideEffectType::kHasSideEffect).ToLocalChecked();
//persistentObject is a weak Global reference with a callback to clean up native resources
this->objectHandle->persistentObject->Get(i)->Set(i->GetCurrentContext(), functionName, myFunc).FromJust();
内存增长,最终出现 OOM 错误和崩溃。查看堆快照后,我发现大部分保留的内存由 noscript_shared_function_infos in(强根)持有。
我的猜测是,要么共享功能信息没有被清理(并且增长,增长和增长),或者更糟糕的是,我的实际功能没有被清理(当不再使用时)。
完成后如何删除信息/或实际功能?
你试过while(!V8::IdleNotification()) {};
吗?noscript_shared_function_infos
不应该由 v8 的 GC 处理吗?
我有同样的问题,但脚本::在新上下文中运行。似乎每次它调用具有function ...() {}
的脚本时,它都会将一些字节附加到noscript_shared_function_infos
弱参考数组,然后永远不会清理它。
我在不同的平台上只发现了一些问题(比如那个),而对 v8 非常了解的人的答案为零。很可悲。
相关文章:
- 将字符串存储在c++中的稳定内存中
- C++ 指针的内存地址和指向数组的内存地址如何相同?
- Win32编译器选项和内存分配
- 当vector是tje全局变量时,c++中vector的内存管理
- 带内存和隔离功能的SQLite
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 迭代时从向量和内存中删除对象
- 在C++中打印指向不同基元数据类型的指针的内存地址
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 多个文件的内存分配错误"在抛出 'std :: bad_alloc' what (): std :: bad_alloc 的实例后终止调用" [C++]
- 为什么示例代码访问IUnknown中已删除的内存
- 如何在C++类内存结构中创建"spacer"?
- 从构造函数抛出异常时如何克服内存泄漏
- malloc() 可能出现内存泄漏
- 如何理解将半精度指针转换为无符号长指针和相关的内存对齐
- 在调用FreeLibrary后,释放动态链接到具有相同版本的CRT堆的DLL的内存
- 如何针对特定情况调试和修复此双自由内存损坏问题
- 类型总是使用其大小存储在内存中吗
- 有没有一种方法可以测量c++程序的运行时内存使用情况
- 有没有一种方法可以使用placement new将堆叠对象分配给分配的内存