作为用C语言进行多处理器编程的实践,我一直在尝试制作一个可以使用文件作为进程之间通信方式的程序,这部分程序应该使用子进程来读取文件的内容并将其复制到临时文件中,然后将它们从临时文件复制到输出文件中(最好是一行一行地这样做)。问题是,在读完文件的所有行而似乎没有出现任何问题之后,循环只是回到第2行,重新开始,一次又一次,一次又一次...出于某种原因。当我使用单个进程时,它工作得很好,但这不是我试图实现的目标。其他似乎有帮助的事情是用write()调用替换fprintf()调用(摆脱了在输出文件中一路重复的行)我想认为问题与fgets在我认为应该返回NULL的时候没有返回有关,但我不知道为什么会发生这种情况。我想我从这一点上得到的唯一教训是永远不要在循环内使用fork(),因为这几乎是我的问题和我找到的解决方案没有共同点的一件事,哈哈。下面是我使用的代码的一些细节:图书馆: #include
#include
#include
#include
#include 所讨论的程序(它位于main()中的一些Assert之后): //opening files with pathnames given as input, creates or overwrites output file
FILE *Nombres = fopen(argv[1], "r");
FILE *Apellidos = fopen(argv[2], "r");
FILE *Output = fopen(argv[3], "w");
//temp file with a fixed name so i can test around
char *tempname = "aaa.txt";
FILE *Tmp = fopen(tempname, "w+");
char linea[MAXIMA_LONGITUD_LINEA];
pid_t hijoid;
while (fgets(linea, MAXIMA_LONGITUD_LINEA, Nombres) != NULL) {
printf("%s\n", linea);
Tmp = fopen(tempname, "w+"); //clear tempfile contents
hijoid = fork();
if (hijoid == 0) {
write(fileno(Tmp), linea, strlen(linea));
exit(0);
} else {
waitpid(hijoid, NULL, 0);
rewind(Tmp);
if (fgets(linea, MAXIMA_LONGITUD_LINEA, Tmp) != NULL) {
write(fileno(Output), linea, strlen(linea));
} else {
printf("Line couldn't be read.\n");
}
}
}
}编辑:**这是一个大学作业,旨在测量使用管道和信号与不使用管道和信号之间的时间差,现在看到这种方法没有任何进展,而且无论如何也不应该这样做,我只是继续使用管道,没有出现很多问题。不介意分享代码,但我认为这已经有点超出主题了。
|