如何在共享内存中测量boost进程间向量的大小?

时间:2014-10-10 18:34:02

标签: c++ boost shared-memory

我使用boost :: interprocess :: vector在进程之间共享一些字符串,我想确保不会溢出它所在的共享内存段。

如何找到向量在内存中占用的空间,以及特殊的段分配字符串将占用多少内存?

typedef boost::interprocess::managed_shared_memory::segment_manager SegmentManager;
typedef boost::interprocess::allocator<char, SegmentManager> CharAllocator;
typedef boost::interprocess::basic_string<char, std::char_traits<char>, CharAllocator> ShmString;
typedef boost::interprocess::allocator<ShmString, SegmentManager> StringAllocator;
typedef boost::interprocess::vector<ShmString, StringAllocator> ShmStringVector;

const size_t SEGMENT_SIZE = ...;

addToSharedVector(std::string localString){
    using namespace boost::interprocess;
    managed_shared_memory segment(open_only, kSharedMemorySegmentName);
    ShmStringVector *shmvector = segment.find<ShmStringVector>(kSharedMemoryVectorName).first;

    size_t currentVectorSizeInShm =  ?????(shmvector);            <--------  HALP!
    size_t sizeOfNewStringInSharedMemory =   ?????(localString);  <--------

    //shared mutex not shown for clarity

    if (currentVectorSizeInShm + sizeOfNewStringInSharedMemory < SEGMENT_SIZE)  {
        CharAllocator charAllocator(segment.get_segment_manager());
        ShmString shmString(charAllocator);
        shmFunctionName = localString.c_str();
        shmvector->push_back(shmString);
    }
}

1 个答案:

答案 0 :(得分:4)

  1. 快速而肮脏

    您可以使共享内存成为物理映射文件,并查看实际已将多少页面提交到磁盘。这为您提供了许多实现的粗略指示,因为页面最有可能在1时提交,并且通常的内存页面大小为4kb。

    我还有另一个答案 [1] ,它向您展示了此方法的基础知识。

  2. 您可以在段管理器上使用get_free_memory()。请注意,这并没有说明该向量的分配/正/为什么,但它为您提供了(实际上更有用)实际占用空间的想法。

  3. another answer [2] 中,我使用它来对具有连续存储和基于节点的容器的数据容器之间的内存开销差异进行基准测试。

    enter image description here

    正如您所看到的,单个分配的开销很高,重新分配会很快导致碎片化。所以值得一看

    • 提前预留空间以防止重新分配
    • 使用专门的Boost进程间分配器来更好地利用共享内存区域

    [1] 参见 Memory Mapped Files, Managed Mapped File and Offset Pointer

    [2] 参见 Bad alloc is thrown