C:popen()函数执行的Linux命令未显示结果

问题描述 投票:8回答:2

[下面有我引用here上的线程以使用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时做错了什么?

如果执行下面的代码(请参阅webpage

#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 

上面的代码有什么错?

c linux popen
2个回答
17
投票

由于输出将转到stderr,因此您需要像这样重定向stderr

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

这会将stderr重定向到stdout,因此您将看到两者的输出。第二期fscanf将在第一个空格处停止,因此您可以替换为fgets

fgets(buffer, 100, file);

2
投票

正确诊断为Shafik Yaghmour后,您从ntpdate中看到的输出将(正确)写入其标准错误,这与程序的标准错误相同。

要获取通过管道发送的错误消息,请使用:

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

将标准错误输出从ntpdate发送到命令的标准输出,这是您正在读取的管道。

当然,在您进行一些配置之前,使用ntpdate似乎无法正常工作。

© www.soinside.com 2019 - 2024. All rights reserved.