我在共享内存中有一个数组。我想使用一个指针迭代这个数组,这也是为了共享。这是我试过的:
/* initialize color sequence in shared memory */
shmkey = ftok("/dev/null",3); /* executable name and a random number */
shmid = shmget(shmkey, sizeof(char), 0700 | IPC_CREAT);
if(shmid < 0){ /* shared memory error check */
perror("shmget\n");
exit(1);
}
queue = (char*) shmat(shmid, NULL, 0); /* shared memory part of colorSequence */
printf("queue allocated.\n");
/* initialize color sequence pointer in shared memory */
shmkey = ftok("/dev/null//",61); /* executable name and a random number */
shmid = shmget(shmkey, sizeof(char), 0700 | IPC_CREAT);
if(shmid < 0){ /* shared memory error check */
perror("shmget\n");
exit(1);
}
p = (char*) shmat(shmid, NULL, 0); /* pointer to queue in shared memory */
printf("queue pointer allocated.\n");
p = &queue[0];
现在我分叉子并尝试更改值p,但是在一个进程中进行的更改不会影响另一个进程。
if(fork() == 0){ /* child process */
sem_wait(&sem);
printf(" Child printing *p=%c, p=%p\n",*p,p);
p++;
printf(" Child printing after++ p=%c, p=%p\n",*p,p);
sem_post(&sem);
exit(0);
}
else{ /* parent process */
sem_wait(&sem);
printf("Parent printing *p=%c, p=%p\n",*p,p);
p+=2;
printf("Parnet printing after++ p=%c, p=%p\n",*p,p);
p = NULL; //even though this, program doesn't fail
sem_post(&sem);
}
然而,输出是(队列的内容如下:R B G ...):
Parent printing *p=R, p=0x7f5c77837000
Parnet printing after++ p=B, p=0x7f5c77837002
Child printing *p=R, p=0x7f5c77837000
Child printing after++ p=G, p=0x7f5c77837001
我无法弄清楚为什么我得到这些结果,即使指针应该被共享。你能帮我解决这个问题吗?感谢。
修改
当我尝试在父进程中更改值p指向时,从子进程打印时效果是可见的。但是增量指针不起作用。
答案 0 :(得分:2)
您实际上有两个问题,但操作系统可以解决这个问题。
第一个问题是您说您的共享内存大小为1(sizeof(char)
)。这可以通过操作系统来减轻,因为它可以将其四舍五入到页面大小。
第二个问题是:
p = (char*) shmat(shmid, NULL, 0); /* pointer to queue in shared memory */
p = &queue[0];
在这里,你从共享内存中获取p
,你用另一个指针覆盖这个指针。
然而,出于两个原因,这是一个没有实际意义的问题:第一个是我评论过的问题。第二个是,即使你没有覆盖指针p
,它仍然是你的过程的“本地”,所以这样做,例如p++
不会更改共享内存中的副本,因为实际指针不会被共享。如果你真的想在共享内存中有一个指针,那么p
就是指向指针的指针,必须(*p)++
来增加本地和共享内存中的指针。