TBB生成任务内存泄漏
TBB spawn task memory leak
我们有一段代码,利用TBB来生成任务来执行一些处理,这是使用以下TBB代码来初始化TBB线程池(以匹配内核数量):
tbb::task_scheduler_init(8);
然后,对于我们想要生成的每个任务,我们使用以下代码(其中MainTask派生自tbb::task类):
task = new (tbb::task::allocate_root()) MainTask(theAction, theOutputData);
tbb::task::enqueue(*task);
当我们运行代码时,我们开始使用一定数量的内存,然后随着程序的执行和生成新的任务,如上所述,内存使用随着时间的推移逐渐增加。在40分钟的执行中,它从12KB增加到213KB。这显然不是我们的任何处理代码的结果,似乎是由于TBB没有释放我们正在创建的TBB allocate_root任务的内存,一旦它们完成了它们的执行,就像我们期望的那样。
为什么会发生这种情况?是否还有其他的东西,我们需要做的是解决这个问题,或者有一些替代方法来生成TBB任务,而不使用allocate_root方法,将解决这个问题?
别担心。TBB缓存和重用任务内存以提高性能。它有特殊的机制来防止生产者-消费者情况下的内存泄漏,即一个线程一直分配任务,而另一个线程只消耗它们。
如果您仍然怀疑存在内存泄漏,则需要进行更详细的测试,以证明内存消耗在初始上升之后不会停止(当然,它是非线性函数)。TBB有专门的单元测试来检测内存泄漏:参见src/test/test_task_leaks.cpp
相关文章:
- 从构造函数抛出异常时如何克服内存泄漏
- malloc() 可能出现内存泄漏
- 这个极客对极客的trie实现是否存在内存泄漏问题
- 尽管遵循了规则,内存泄漏在哪里
- 为什么调用堆栈数组会导致内存泄漏
- 在简单示例中,Python3 + ctypes 回调会导致内存泄漏
- 使用模板类的自定义列表类型中的内存泄漏
- 为什么以下C++代码中存在内存泄漏?
- OpenCV 我应该使用智能指针来防止内存泄漏吗?
- 我是否生成线程并导致内存泄漏?
- 多线程程序中出现意外的内存泄漏
- 为什么此函数会导致内存泄漏?
- 在 C++ 库中使用cythonized python时内存泄漏
- 需要帮助查找内存泄漏
- 瓦尔格林德的内存泄漏使用新的
- 无法找出我的代码中的内存泄漏
- C++ 结构内部的unordered_map会导致内存泄漏问题吗?
- 可视化 使用 VS Code 查找C++应用程序中的内存泄漏
- Shared_ptr双链接列表内存泄漏
- C++ 在类中使用常量引用文本时 O2 内存泄漏