如何与shm_open共享现有内存?

时间:2014-02-18 08:21:12

标签: c linux shared-memory

在Linux中,我想与其他进程共享我的进程的一些内存内容。 其中一种方法是使用shm_open和mmap。如下。

/* Create a new memory object */
fd = shm_open( "/bolts", O_RDWR | O_CREAT, 0777 );
if( fd == -1 ) {
    fprintf( stderr, "Open failed:%s\n",
        strerror( errno ) );
    return EXIT_FAILURE;
}

/* Set the memory object's size */
if( ftruncate( fd, sizeof( *addr ) ) == -1 ) {
    fprintf( stderr, "ftruncate: %s\n",
        strerror( errno ) );
    return EXIT_FAILURE;
}

/* Map the memory object */
addr = mmap( 0, sizeof( *addr ),
        PROT_READ | PROT_WRITE,
        MAP_SHARED, fd, 0 );
if( addr == MAP_FAILED ) {
    fprintf( stderr, "mmap failed: %s\n",
        strerror( errno ) );
    return EXIT_FAILURE;
}

但是,通过这种方式,我无法共享“已经分配的内存”。 我的问题是: 我可以共享以前分配的内存内容而无需重新分配它们吗?

提前谢谢。

1 个答案:

答案 0 :(得分:3)

您的代码确实共享内存,但您的进程将获得不同的地址区域。您希望拥有相同的区域,因此addr值将相同。在这种情况下,您可以在此内存中构建对象,使用内部指针,您的对象在两个进程中都是有效且可见的。

有两种方法可以做到这一点。

1)执行fork()以创建另一个进程

2)要求mmap使用MAP_FIXED在特殊地址分配内存。

对于第二个,您的代码将会显示:

/* Create a new memory object */
fd = shm_open( "/bolts", O_RDWR | O_CREAT, 0777 );
if( fd == -1 ) {
    fprintf( stderr, "Open failed:%s\n",
        strerror( errno ) );
    return EXIT_FAILURE;
}

/* Set the memory object's size */
if( ftruncate( fd, sizeof( *addr ) ) == -1 ) {
    fprintf( stderr, "ftruncate: %s\n",
        strerror( errno ) );
    return EXIT_FAILURE;
}

// You base address for memory region that you want to share. 
// Choose this carefully, you both processes MUST have it available!
void * baseAddr = 0x7fff00000000; 

/* Map the memory object */
addr = mmap( baseAddr, sizeof( *addr ),
        PROT_READ | PROT_WRITE,
        MAP_SHARED | MAP_FIXED, fd, 0 );

if( addr == MAP_FAILED | MAP_FIXED ) {
    fprintf( stderr, "mmap failed: %s\n",
        strerror( errno ) );
    return EXIT_FAILURE;
}

image