我试图找到一种方法使这个算法并发运行并同步。到目前为止,只有1个for循环读取每个文件,然后为每个文件创建一个进程。
我相信这个算法按顺序运行,这不是我想要的...... 我想创建一个外部for循环,我把wait(null)和read命令放在一起。但是,当我尝试它不起作用,没有产生输出。目前我在父进程中有wait(null)命令。
有什么建议吗?
代码:
int main(int argc, char *argv[])
{
// ATTRIBUTES //
int freq[argc-1], ipc[argc][2], nbytes, i;// freq of words, pipes, counters
ssize_t errorfi;
char readbuffer[9999];
char** k = malloc(50);
char** op = malloc(50);
if(argc == ONE) { // there are no files given, throw error and close
fprintf(stderr, "There are no files found from %s\n", argv[0]);
exit(0);
}
for(i = 1; i < argc; i++) // creates pipes for ipc
pipe(ipc[i]);
pid_t pids[argc-1]; // array of pids
for(i = 1; i < argc; i++) { // reads input after position 0(a.out)
pid_t pid = fork(); // creates process
pids[i-1] = pid;
if( pid < 0 ) { // bad fork process: error
perror("bad fork");
exit(0);
}
else if(pid > 0) { //parent process
close(ipc[i][1]);
wait(NULL);
nbytes = read(ipc[i][0], readbuffer, sizeof(readbuffer));
if(nbytes > 0)
printf("%s\n", readbuffer);
}
else if(pid == 0) { // child process
close(ipc[i][0]);
k = inputReader(argv[i]); // finds filename,w1,w2,w3,uniqueWords
char info[50] = "";
strcat(info, k[0]);
strcat(info, " ");
strcat(info, k[1]);
strcat(info, " ");
strcat(info, k[2]);
strcat(info, " ");
strcat(info, k[3]);
strcat(info, " ");
strcat(info, k[4]);
int uniqueWordint = atoi(k[4]);
freq[i-1] = uniqueWordint; // freq of all uniqueWords
errorfi = write(ipc[i][1], info, strlen(info)+1); // writes info to pipe i
if (errorfi < 0 ) {
fprintf(stderr, "error found when writing in pipe errofi: %d\n", errorfi);
exit(0);
}
exit(0); // close process
} // closes child process
} // closes for-loop for each process
for(j = 0; j < argc-1; j++) {
wait(2); // if i put read command here it won't work
}
return(0); // close main
}
答案 0 :(得分:0)
这确实是一个顺序执行。父进程进入循环,分叉子进程,然后它不会继续到下一个循环,直到子进程完成。
您可以做的是创建一个pid_t
大小为argc
的数组,以存储每个fork()
的返回值。
在每个进程&#34;之后为#34; for循环创建一个新循环,其中父进程将使用wait(2)
或waitpid(2)
等待他的所有孩子,具体取决于您是否需要按照特定顺序处理每个孩子的结果,并继续处理它们(read
或任何需要的。