C中的并发程序(顺序问题)

时间:2015-01-31 09:34:54

标签: c linux concurrency fork system-calls

我试图找到一种方法使这个算法并发运行并同步。到目前为止,只有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 
 }  

1 个答案:

答案 0 :(得分:0)

这确实是一个顺序执行。父进程进入循环,分叉子进程,然后它不会继续到下一个循环,直到子进程完成。

您可以做的是创建一个pid_t大小为argc的数组,以存储每个fork()的返回值。 在每个进程&#34;之后为#34; for循环创建一个新循环,其中父进程将使用wait(2)waitpid(2)等待他的所有孩子,具体取决于您是否需要按照特定顺序处理每个孩子的结果,并继续处理它们(read或任何需要的。