我应该编写一个程序,将整数写入共享内存,派生子进程,子进程应该读取整数。
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,但在主进程中不是。
谢谢
答案 0 :(得分:2)
我相信如果您将#define N_SHARED 2000
更改为#define N_SHARED 2000*sizeof(int)
,您的代码应该按预期工作。
shmat
分配大小等于size的值的共享内存,向上舍入为PAGE_SIZE的倍数。您的代码尝试分配2000个字节,舍入为4096,即1024 * sizeof(int)
。这解释了为什么第一个1024 int具有预期值。