5

测试程序:

#include <tbb/parallel_invoke.h>

int main(void)
{
    tbb::parallel_invoke([]{},[]{});
    return 0;
}
  1. 编译使用g++ -std=c++11 tmp.cpp -ltbb
  2. 检查与

    valgrind --tool=memcheck --track-origins=yes \
             --leak-check=full --log-file=report ./a.out`
    
  3. libtbb版本:4.0valgrind版本:3.8.1

上述部分测试结果:

possibly lost: 1,980 bytes in 6 blocks

问题是:

这是一个TBB错误吗?

还是这possible lost实际上是安全的,只是valgrind认为不安全的一些代码?

4

1 回答 1

2

最有可能的是,这是误报,而不是错误。至少有几个原因:

  1. TBB 使用自己的内存分配器libtbbmalloc,它会缓存内存直到进程终止,并且可能会出现泄漏。
  2. TBB 线程异步运行和终止。很可能在main()终止后,工作线程仍在运行。它给 valgrind 带来了同样的印象

为了合理地指责 TBB 泄露,排除上述因素,例如:

  1. 删除 libtbbmalloc.so.2 或 tbbmalloc.dll 文件,因此使用 env.variable 运行应用程序TBB_VERSION=1将输出TBB: ALLOCATOR malloc但不TBB: ALLOCATOR scalable_malloc
  2. 确保所有 TBB 线程都已终止

例如

int main()
{
    assert(tbb::tbb_allocator<int>::allocator_type() != tbb::tbb_allocator<int>::scalable);
    { // TBB scope
        tbb::task_scheduler_init scope;
        tbb::parallel_invoke([]{},[]{});
    } // TBB threads start termination here
    sleep(10); // wait for threads to terminate
    return 0;
}
于 2014-06-10T16:22:21.447 回答