我有以下代码,它应该创建一个forked进程来执行Collatz猜想(基于传递的值),并将整数推送到共享内存中。子进程完成后,父进程应该打印出值。出于某种原因,我的代码有时会起作用而不会起作用。从调试语句中,我可以看到值被推入,但有时打印出值的代码似乎没有执行(只有一些空行被打印)。我在虚拟框中使用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;
}
有关我做错的任何提示?
答案 0 :(得分:0)
有两个fork()调用。这将创造两个孩子。
pid = fork();
//fork();
你能尝试一下吗?