尝试使用子进程写入共享内存中的int(使用mmap)

时间:2013-10-30 02:30:39

标签: c mmap

我正在玩一些代码,需要在父代和分叉子进程之间进行通信。我在fork之前在共享内存中创建了一个int,但是我对子进程所做的任何更改似乎都不会影响父进程访问时的int。这是一段代码,说明了我的问题。

int * shared = mmap(NULL, sizeof(int), PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0); 
pid_t child;
int childstate;
if((child=fork())==0){
      *shared = 1;
      exit(0);
}
waitpid (child, &childstate, 0); 
printf("%d",*shared);

虽然子进程将'shared'的值设置为1,但此程序输出0。

在我的实际程序中,将共享一个结构而不是一个int,但是如果我能弄清楚这个代码片段,我认为其余部分应该落实到位。

我不是一个经验丰富的程序员,而且我对C有点不熟悉。我花了好几个小时试图解决这个问题并阅读了几十页,说这应该是一个简单的过程。说实话,这对我的自尊心是一个沉重的打击:)。我确定我只是错过了一些细节 - 有人能指出我吗?提前感谢您的时间。

1 个答案:

答案 0 :(得分:8)

您的问题是传递到mmap()的标记,您需要MAP_SHARED

int * shared = mmap(NULL, sizeof(int), PROT_READ|PROT_WRITE, MAP_SHARED|MAP_ANONYMOUS, -1, 0); 

按预期使用以下代码

#include <sys/mman.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <stdio.h>

int main(void) {
    int * shared = mmap(NULL, sizeof(int), PROT_READ|PROT_WRITE, MAP_SHARED|MAP_ANONYMOUS, -1, 0); 
    pid_t child;
    int childstate;
    printf("%d\n", *shared);
    if((child=fork())==0){
            *shared = 1;
            printf("%d\n", *shared);
            exit(0);
    }
    waitpid (child, &childstate, 0); 
    printf("%d\n",*shared);
}

输出:

0
1
1

mmap man page可能会帮助您,如果您还没有找到它。