10

関数を使用するためにここでスレッドを参照する以下のコードがありますpopen

int main(int argc,char *argv[]){    
    FILE* file = popen("ntpdate", "r");
    char buffer[100];
    fscanf(file, "%100s", buffer);
    pclose(file);
    printf("buffer is :%s\n", buffer);
    return 0;
}

以下を出力します。

21 Apr 03:03:03 ntpdate[4393]: no server can be used, exiting
buffer is:

なぜprintf何も出力しないのですか?コマンドとして使用するlsと、printf は ls 出力を出力します。私は何を間違ってntpdate実行していますか?

以下のコードを実行すると(Webページを参照)

#define COMMAND_LEN 8
#define DATA_SIZE 512

int main(int argc,char *argv[]){


    FILE *pf;
       char command[COMMAND_LEN];
       char data[DATA_SIZE];

       // Execute a process listing
       sprintf(command, "ntpdate");

       // Setup our pipe for reading and execute our command.
       pf = popen(command,"r");

       if(!pf){
         fprintf(stderr, "Could not open pipe for output.\n");
         return;
       }

       // Grab data from process execution
       fgets(data, DATA_SIZE , pf);

       // Print grabbed data to the screen.
       fprintf(stdout, "-%s-\n",data);

       if (pclose(pf) != 0)
           fprintf(stderr," Error: Failed to close command stream \n");

       return 0;
}

私は得る

21 Apr 03:15:45 ntpdate[5334]: no servers can be used, exiting
-�2}�����"|�4#|�-
 Error: Failed to close command stream 

上記のコードの何が間違っていますか?

4

2 に答える 2

19

出力が次のようにリダイレクトされるため、次のようstderrにリダイレクトする必要があります。stderr

FILE* file = popen("ntpdate 2>&1", "r");

これはにリダイレクトされるstderrためstdout、両方からの出力が表示されます。2 番目の問題fscanfは最初のスペースで停止するため、次のように置き換えることができますfgets

fgets(buffer, 100, file);
于 2013-04-21T01:37:42.923 に答える
2

Shafik Yaghmour が正しく診断したように、表示される出力は標準ntpdateエラーに (正しく) 書き込まれます。これは、プログラムの標準エラーと同じです。

パイプを介して送信されるエラー メッセージを取得するには、次を使用します。

FILE *file = popen("ntpdate 2>&1", "r");

ntpdateこれにより、標準エラー出力が、読み取り元のパイプであるコマンドの標準出力に送信されます。

もちろん、ntpdate何かを設定するまではうまく使えないようです。

于 2013-04-21T01:36:42.053 に答える