父母和1个孩子之间的IPC。

时间:2017-04-20 15:55:53

标签: c ipc

我正在练习父进程和1个孩子之间的进程通信。我想要做的是,孩子发送父母的每条消息都会读取它(某种阻塞发送,父母必须在孩子继续发送另一条消息之前先阅读该消息)。我不能用管子。我已经读过关于阻止发送的Silberschatz书,但我还没有找到一个很好的例子(也许是邮箱)。你能帮忙的话,我会很高兴! 这是一段代码:

int main(int argc, char** argv) {
printf("This process: ");
printf("%d\n",getpid());
printf("Parent: ");
printf("%d\n",getppid());
pid_t f;
int input;
f = fork();
if (f == 0) {
    for(int i=0;i<5;i++){
        printf("Input a number: ");
        scanf("%d",&input);
        send(getppid(),input);
    }
    printf("\n");
    exit(0);
} else { 
recv(f,input);
printf("%d",input);
}
wait();
exit(0);

}

1 个答案:

答案 0 :(得分:0)

这是一个可怕的黑客,但有效:/ 您应该使用信号量或某种信令到共享内存。 为ftok(createthisfile.txt)创建文件。 这是对共享内存块进行密集轮询并使用&#34;代码&#34; (int = 99)表示子循环的子节点已完成。请注意,99不能用作数字,否则父母会提前退出。作为最后一点,你正在研究这个问题,然后你应该自己解决问题,得到提示和提示,但不要让别人为你工作:/否则你将主要从事stackoverflow,而不是计算机科学:)我做了这是一个快速的练习,但遗憾地发布它:/

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <sys/types.h>

int main(int argc, char** argv) {
   key_t k;
   pid_t f;
   int shmid;
   int input;

   printf("This process: ");
   printf("%d\n",getpid());
   printf("Parent: ");
   printf("%d\n",getppid());

   k = ftok ("createthisfile.txt", 'R');
   shmid = shmget(k, sizeof(int), IPC_CREAT|SHM_R|SHM_W);
   char *addr = shmat(shmid,0,0);

   f = fork();

   if (f == -1) {
      exit(1);
   }

   if (f == 0) {
      for(int i=0;i<5;i++){
         printf("Input a number: ");
         scanf("%d",&input);
         memcpy(addr, &input, sizeof(int));
      }
      input = 99;
      memcpy(addr, &input, sizeof(int));
      printf("\n");
      exit(0);
   } else { 
      while (1) {
         memcpy(&input, addr, sizeof(int));
         if (input != 0) { 
            if (input == 99) {
               exit (0);
            }
            printf("[Parent reads: %d]\n",input);
            input = 0;
            memcpy(addr, &input, sizeof(int));
         }
      }
   }

   exit(0);
}