我对此表示怀疑。
对于tbb::memory_pool< tbb::scalable_allocator > shared_memory_pool_;
如果它是在主线程中实例化的。然后,我在工作线程中调用了shared_memory_pool_.malloc(sizeof(my_class))。tbb是从主堆分配内存大小,还是从线程"domain“分配内存,以便仍然可以避免由普通malloc()引起的锁争用?
发布于 2014-04-27 17:32:38
tbb::memory_pool基于与tbb::scalable_allocator相同的内部结构。因此,一旦内存池最初获取内存(在您指定的情况下,也是从tbb::scalable_allocator获取),它将使用相同的机制跨线程分配和重用内存。即它是可伸缩的,并且尽可能地避免全局锁。尽管如此,由于内存仍然是一种公共资源,因此无论如何线程同步都是不可避免的。
至于scalable_allocator最初的内存分配,它会通过mmap或VirtualAlloc分配足够大的内存块,而不是通过malloc。
发布于 2017-09-26 12:28:40
Here是关于如何正确实现内存池的一些有用的描述。请注意,根据这一点:
在我们的实现中,我们试图以线程安全和可伸缩的方式提供更通用的功能。为此,内存池的实现基于TBB可伸缩内存分配器,因此具有类似的速度和内存消耗属性。
希望这能有所帮助。
https://stackoverflow.com/questions/15490418
复制相似问题