我在 C++ 项目中使用谷歌记录器 (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++ 新手,所以如果这非常简单;抱歉 - 提前致谢!
最佳答案
不确定 glog,但通常我们使用 dup2 系统调用将一个文件处理程序的输出重定向到另一个文件处理程序。
例如在你的情况下,让所有 std::cout 写入 glog 使用的日志文件就可以了
dup2(glog_file_handler,标准输出);
如果您能找到 glog 正在写入的日志文件的文件句柄,那么这会起作用。引用http://man7.org/linux/man-pages/man2/dup.2.html了解更多详情。
希望这对您有所帮助。
附言如果你的程序有多个线程/进程写入同一个 glog 文件并且 glog 同步写入日志文件,这将不起作用
关于c++ - 如何发送到 Google Logger 和 cout?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41166257/