1

我在 C++ 项目中使用 google logger (glog),其中源代码包含信息项和进度的打印输出:

std::cout << some_useful_stuff << "\n";

我可以使用 GLOG 来记录信息项:

LOG(INFO) << some_useful_stuff << "\n"; \\ gets echoed to stdout

我无法更改std::cout整个代码库中的所有语句(因为我正在使用来自第三方的一些子存储库等,并且无法向它们添加我自己的日志记录语句),这使我无法使用 if-else 构造(这将是无论如何都很难看,将每个输出语句包装在逻辑中)。

那么如何将stdout输出复制到 GLog 呢?

std::cout << some_useful_stuff << "\n"; \\ message also goes to LOG(INFO)

可能有用:我实际上不需要同时发生这种情况;有一个像 {CONSOLE, LOGS, BOTH} 这样的选择很有用,但我可以忍受 {CONSOLE, LOGS} 之间更简单的选择。

另外 - 经验丰富的程序员,但 C++ 新手,所以如果这很简单;道歉 - 并提前感谢!

4

1 回答 1

0

不确定 glog,但通常我们使用 dup2 系统调用将一个文件处理程序的输出重定向到另一个文件处理程序。

例如,在您的情况下,让所有 std::cout 写入 glog 使用的日志文件即可

dup2(glog_file_handler,标准输出);

如果您可以了解如何获取 glog 正在写入的日志文件的文件句柄,这将起作用。有关详细信息,请参阅http://man7.org/linux/man-pages/man2/dup.2.html

希望这可以帮助。

PS 如果您的程序有多个线程/进程写入同一个 glog 文件并且 glog 确实同步写入日志文件,这将不起作用

于 2016-12-15T14:31:51.950 回答