3

在一个程序中,我希望将所有 printfs 写入 syslog。我将所有 printf 替换为 syslog,所以我想将 stdout 和 stderr 重定向到 syslog。为此,我尝试了以下代码

int main()
{
    FILE *fl;
    fl = popen("logger","w");
    if(fl == NULL)
        return 1;
    fprintf(fl,"logger test new");//this goes to /var/log/messages
    int nf;
    nf = fileno(fl);
    dup2(nf,STDOUT_FILENO);
    dup2(nf,STDERR_FILENO);
    fprintf(stdout,"Wriiten in stdout\n");
    fprintf(stderr,"Wriiten in stderr\n");
    pclose(fl);
}

问题是 stderr 进入 syslog 并且屏幕上没有打印任何内容并且程序被挂起。请建议。

4

2 回答 2

4
dup2(nf,STDOUT_FILENO);
dup2(nf,STDERR_FILENO);
fprintf(stdout,"Wriiten in stdout\n");
fprintf(stderr,"Wriiten in stderr\n");
fflush(stdout);

这应该解决它。

fflush()将强制从标准输出写入缓冲数据。

于 2013-01-24T16:12:24.590 回答
2

另一种方法fflush(stdout)是使用以下命令禁用标准输出缓冲:

setbuf (stdout,NULL);
于 2014-08-17T13:41:01.010 回答