我在shared memory
中保留两个对象,其中一个是以下类:
class GlobalObj
{
public:
unsigned int counter;
unsigned int label;
bool isExist;
Globals(void){}
~Globals(void){};
};
另一个是boost::multi_index_container
,它拥有该类型对象:
class TestObj
{
public:
long id;
unsigned _int64 track1;
unsigned _int64 track2;
int label;
MetaData(void){};
~MetaData(void){};
};
所以当我构建共享内存时,我会用这种方式计算大小:
// TEST_CONTAINER_SIZE is a constant which is the
// maximum number of record that multi_index container will keep
size_t containerSize = TEST_CONTAINER_SIZE * sizeof(TestObj);
// create shared memory
managed_shared_memory segment(create_only,"SharedMemory", containerSize + sizeof(GlobalObj));
所以当我设置TEST_CONTAINER_SIZE = 10000;
时,我希望我可以将10000 TestObj
插入共享内存中的multi_index容器中。但是当我运行该程序时
它会触发与3071th
项中的共享内存大小相关的异常。
multi_index容器本身是否有任何开销,或者在计算共享内存大小时是否遗漏了其他任何内容?
感谢。
修改
所以在我当前的实现中,我的multi_index容器和分配如下所示:
typedef multi_index_container<
TestObj,
indexed_by<
ordered_unique<member<TestObj, long, &TestObj::id> >,
ordered_non_unique< member<TestObj, unsigned _int64, &TestObj::track1> >
>,
boost::interprocess::managed_shared_memory::allocator<TestObj>::type
> ContainerType;
segment = new managed_shared_memory(open_only, "SharedMemory");
DataContainer = segment->construct<ContainerType>
("DataContainer") //Container's name in shared memory
( ContainerType::ctor_args_list()
, segment->get_allocator<TestObj>());
因为我知道我的容器中有多少项目,分配它的最有效和最稳定的方法是什么?
答案 0 :(得分:0)
这完全取决于实现,不能假设任何有关容器的大小。您可能希望将自定义allocators
与multi_index容器一起使用。
答案 1 :(得分:0)
管理共享内存段需要很多开销。
你应该让分配器弄明白,或从段中分配这些对象的连续范围,这样你就可以准确地预测所需的内存量。
在这个答案中,我用managed_shared_memory
对比了一些分配开销:
一张图片说千言万语:
如您所见,高度的内存量取决于您管理分配的方式。