C Sharedmemory在分叉进程中只有1024 int

时间:2017-06-16 20:46:57

标签: c shared-memory freebsd

我应该编写一个程序,将整数写入共享内存,派生子进程,子进程应该读取整数。

shm.c

#define N_SHARED 2000

int main(int argc, char **argv) {
/* Ein Shared-Memory-Segment einrichten */
shmid = shmget(IPC_PRIVATE, N_SHARED, IPC_CREAT | SHM_R | SHM_W);

if (shmid == -1) {
 perror("shmid");
 exit(1);
}

 /* Pointer zu Sharedm-Memory-Segment erhalten */
shmData = (int *)shmat(shmid,0, N_SHARED);
if (shmData == (int *)(-1)) {
  perror("shmat");
  exit(1);
}

/** ininitalisieren des Zufallsgenerator durch aktuellen Zeitstempel */
srand48(time(NULL));
for (i=0; i<N_SHARED; i++) {
 shmData[i] = lrand48();
 printf("SHM-->%d-->%d\n",i+1,shmData[i]);
}

  pid = fork();

  snprintf(shmidArg,32, "%d", shmid);

  // Kindprozess
  if (pid == 0) {
    execlp("./shm_child",shmidArg,NULL);
  } else if (pid < 0) {
        perror("Kindprozess konnte nicht erzeugt werden!");
        return 1;
  }

shm_child.c

  #define N_SHARED 2000

  int i;
  int *shmData;
  static int shmid;

  int main(int argc, char **argv) {
    shmid = atoi(argv[0]);
    printf("shm_child shared memoryid:%d\n",shmid);

    /* Shared-Memory laden */
    shmData = (int *)shmat(shmid,0,0);
    if (shmData == (int *)(-1)) {
        perror("shmat");
        exit(1);
    }


    for(i=0;i<N_SHARED;i++) {
      printf("%d --> %d\n",i+1,shmData[i]);
    }

我的问题:索引1024之后的每个数字在child_process中都是0,但在主进程中不是。

谢谢

1 个答案:

答案 0 :(得分:2)

我相信如果您将#define N_SHARED 2000更改为#define N_SHARED 2000*sizeof(int),您的代码应该按预期工作。

shmat分配大小等于size的值的共享内存,向上舍入为PAGE_SIZE的倍数。您的代码尝试分配2000个字节,舍入为4096,即1024 * sizeof(int)。这解释了为什么第一个1024 int具有预期值。