boost共享内存对象中的指针

时间:2015-03-03 02:40:05

标签: c++ pointers boost shared-memory

我正在处理boost::interprocess::shared_memory_object,而我想要达到的目标就是这样。

我定义了自己的类SharedMemory,其中有一个方法 调用CreateSharedMemory(),创建一个内存块。我需要在此内存块中保留三个数组Foo a1[SIZE], Foo a2[SIZE]Foo a3[SIZE],以便我可以始终将数据写入其中。 Foo是我自己定义的类。要访问这三个数组,我需要在我的进程中获取它们的地址。所以我将三个指针Foo *p1, *p2, *p3传递给此方法以记录其地址。这个方法一切顺利,但一旦它推出这个方法,p1, p2, p3指向错误的地址。有人可以帮忙吗?

// Foo.h
class Foo
{
   double f[MAX_SIZE];
   char c[MAX_SIZE];
}

// SharedMemory.cpp
void SharedMemory::CreateSharedMemory(Foo *p1, Foo *p2, Foo *p3)
{
   boost::interprocess::shared_memory_object shm
      (boost::interprocess::create_only
      ,"foo"              //name
      ,boost::interprocess::read_write
      );
   shm.truncate(blockSize);

   //Map the whole shared memory in this process
   boost::interprocess::mapped_region region(shm, boost::interprocess::read_write);
   //Write all the memory to 0
   memset(region.get_address(), 0, region.get_size());

   // assign address
   p1 = static_cast<Foo *>(region.get_address());
   p2 = static_cast<Foo *>(region.get_address() + blockSize / 3);
   p3 = static_cast<Foo *>(region.get_address() + 2 * blockSize / 3);

   // p1, p2, p3 point to the correct address here
}

// p1, p2, p3 point to the wrong address once it steps out CreateSharedMemory()

1 个答案:

答案 0 :(得分:0)

您必须传递对Foo指针的引用。像:

void SharedMemory::CreateSharedMemory(Foo* & p1, Foo* & p2, Foo* &p3)