1

C プログラムには、文字で表されるいくつかのオプションから選択できるメニューがあります。プロセスをフォークして関数を実行するオプションがあります (バックグラウンドで実行されると言えます)。いくつかの条件下でバックグラウンドで実行されるこの関数は、ユーザーにデータの入力を求めることができます。

私の問題は、メイン プロセスがデータ (またはオプション) を要求し、子プロセスもデータを要求している場合、データを適切に送信できないことです。

これに対処する方法について何か考えはありますか?

コードの構造を少し追加します (約 600 行のコードがあるため、すべてを投稿することはできません)。

int main(int argc, char *argv[])
{
    // Some initialization here
    while(1)
    {
        scanf("\n%c", &opt);

        switch(opt)
        {
            // Some options here
            case 'r':
                send_command(PM_RUN, fiforfd, fifowfd, pid);
                break;
            // Some more options here
        }
     }
 }

 void send_command(unsigned char command, int fiforfd, int fifowfd, int pid)
 {
     // Some operations here
     if(command == PM_RUN)
     {
         time = microtime();                
         childpid = fork();
         if(childpid == -1)
         {
             // Error here
         }   
         else if(childpid == 0)
         {
             // Here is the child
             // Some operations and conditions here
             // In some condition, appears this (expected a short in hexadecimal)
             for(i = 0; i < 7; ++i)
                 scanf("%hx\n",&data[i]));
             // More operations
             exit(0);
          }
      }
  }
4

1 に答える 1

1

機能していませんが、解決の始まりになる可能性があります

void    send_command(int *p)
{
  pid_t pid;

  pid = fork(); // check -1
  if (pid == 0)
    {
      int       i = 0;
      int       h;
      int       ret;
      char      buffer[128] = {0};

      dup2(p[0], 0);
      while (i < 2)
        {
          if ((ret = scanf("%s\n", buffer)))
            {
              //get your value from the buffer
              i++;
            }
        }
      printf("done\n");
      exit(1);
    }
}

子プロセスでは、入力からすべてを読み取り、内部で必要な値を見つけます。

int     main()
{
  char  opt;
  int   p[2];

  pipe(p);
  while(1)
    {
      scanf("\n%c", &opt);


      write(p[1], &opt, 1);
      write(p[1], "\n", 1);

      switch(opt)
        {
          // Some options here
        case 'r':
          {
            send_command(p);
            break;
          }
        default:
          break;
          // Some more options here
        }
    }
}

現在のケースでは、読み取った各文字は、p[0] で読み取った子プロセスに書き込まれます。

もちろん、多くの子プロセスがある場合は、ファイル記述子のリストを用意して、それぞれに書き込む必要があります (そして、子プロセスごとにパイプを呼び出します)。

幸運を

編集:おそらく、親プロセスがすべてを書き込み、すべての子プロセスが同じものを読み取るnamedpipeを確認する必要があります

于 2013-07-26T15:19:00.547 に答える