6

如何被动收听 stderr 并将其作为字符串获取以发送到回调?我看过有关阅读 stderr 的帖子,但我想听它而不是积极阅读它。

背景:我有一个使用 3rd 方库 (libcurl) 的跨平台作品,它将详细信息输出到 stderr。这个跨平台部分将被超过 1 个非跨平台应用程序使用。

我想记录这些信息,我可以通过向 libcurl 提供 FILE* 来做到这一点。但我不想这样做,而是想看看我是否可以将 stderr 中的输出捕获(被动监听)为 string,并通过回调发送回调用主应用程序。这样做的好处是 1. 主应用程序可以使用它想要的任何日志工具来保留单个日志。2. 它将保持这件作品跨平台。

4

1 回答 1

2

在单个进程中执行此操作有点棘手,但您可能可以做到。

  • 1:使用 freopen() 你可以将你的标准错误重定向到一个命名文件。您可以同时打开该文件以在另一个句柄上读取。您可能还需要在 stderr 上调用 setvbuf() 以关闭输出到 stderr 的缓冲,以便您能够立即从第二个句柄读取它。由于它正在被写入文件,因此您可以在任何时候阅读它——在方便的时候。如果您想在文件更改时收到通知,则需要使用 unix 函数“选择”。(另见 fileno())。

  • 2:更棘手的是将 stderr 设置为管道的写入端。使用 dup3() 应该是可行的,尽管这不完全是跨平台的(对于非 unixy 操作系统)。它还需要第二个线程从管道中读取,以防止写入器在写入量很大时被阻塞。

像:

FILE *stream = freopen("stderr.out", "w", stderr); // Added missing pointer
setvbuf(stream, 0, _IONBF, 0); // No Buffering
FILE *input = fopen("stderr.out", "r");
fprintf(stderr, "Output to stderr dude\n");
//fflush(stderr); // You can explicitly flush instead of setting no buffering.
char buffer[1024];
while (fgets(buffer, 512, input))
{
    printf(">>>%s\n", buffer);
}
于 2012-11-25T05:45:09.590 回答