在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;
}
但是,通过这种方式,我无法共享“已经分配的内存”。 我的问题是: 我可以共享以前分配的内存内容而无需重新分配它们吗?
提前谢谢。
答案 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;
}