共享内存与分叉的孩子

时间:2015-10-13 03:10:38

标签: c linux fork shared-memory

我有以下代码,它应该创建一个forked进程来执行Collat​​z猜想(基于传递的值),并将整数推送到共享内存中。子进程完成后,父进程应该打印出值。出于某种原因,我的代码有时会起作用而不会起作用。从调试语句中,我可以看到值被推入,但有时打印出值的代码似乎没有执行(只有一些空行被打印)。我在虚拟框中使用Debian Linux。

#include <stdio.h>
#include <stdlib.h>
#include <fcntl.h>
#include <sys/shm.h>
#include <sys/mman.h>

int main()
{
   const int SIZE = 2048;
   const char *name = "SHARON";
   int  shm_fd;
   void *ptr;
   int count = 1;

   /* Setup shared memory */
   shm_fd = shm_open(name, O_CREAT | O_RDWR, 0666);
   ftruncate(shm_fd, SIZE);
   ptr = mmap(0, SIZE, PROT_WRITE, MAP_SHARED, shm_fd, 0);

   /* Get the starting value */
   int value;
   printf("Enter a positive integer value: ");
   scanf("%d", &value);
   printf("\n");
   if (value < 0)
   {
      printf("ERROR: Integer value must be positive!");
      return 1;
   }

   /* Fork child process */
   pid_t pid;
   pid = fork();

   fork();
   if (pid < 0)
   {
      fprintf(stderr, "FORK FAILED\n");
      return 1;
   }
   else if (pid > 0) /*parent process*/
   {
      wait();  /*wait for child to send */
      while (atoi((char *)ptr) != 0)   /*0 is terminate value*/
      {
         printf("%s", (char *)ptr);
         ptr += sizeof(int);
         if (atoi((char *)ptr) != 0)
            printf(", ");
      }

      printf("\n");
      shm_unlink(name);
   }
   else if (pid == 0)   /* child process */
   {
      sprintf(ptr, "%d", value);
      ptr += sizeof(value);

      while (value != 1)
      {
         if (value % 2 == 0)
            value /= 2;
         else
            value = value * 3 + 1;

         sprintf(ptr, "%d", value);
         ptr += sizeof(value);
      }
      sprintf(ptr,"0");   //push a "terminate" value
      ptr += sizeof(value);
   }
   return 0;
}

有关我做错的任何提示?

1 个答案:

答案 0 :(得分:0)

有两个fork()调用。这将创造两个孩子。

  pid = fork();

   //fork();

你能尝试一下吗?