我不能在循环中使用 spdlog 记录器

Posted

技术标签:

【中文标题】我不能在循环中使用 spdlog 记录器【英文标题】:I can't use spdlog loggers in a loop 【发布时间】:2020-10-14 16:44:07 【问题描述】:

我想通过循环创建日志。这是一个简单的例子:

#include <iostream>
#include "logging.hpp"

int main(int argc,char* argv[])

        for(int i=1; i<argc; i++)
                Logger l(argv[i]);
        return 0;


这是logging.hpp文件内容:

#include "spdlog/spdlog.h"
#include "spdlog/sinks/stdout_color_sinks.h"
#include <iostream>

class Logger
        public:
                Logger(std::string msg)
                        auto console = spdlog::stdout_color_mt("console");
                        console->info(msg);
                
;

它编译没有问题,但是当我运行带有多个参数的程序时,它会发生错误:

[2020-10-14 20:12:30.067] [console] [info] .<first-argument>
terminate called after throwing an instance of 'spdlog::spdlog_ex'
  what():  logger with name 'console' already exists
Aborted (core dumped)

【问题讨论】:

我认为错误信息很明确:您只能创建一个实例。例如,您可以创建 console 记录器 static。这将确保整个程序中只有一个名为“console”的实例 @Botje 你知道解决方案是什么吗? 您是在尝试将多条消息记录到ONE 日志,还是创建多个日志并为每个日志写入一条消息(就像您现在所做的那样)? 【参考方案1】:

快速而肮脏的解决方法是:

static auto console = spdlog::stdout_color_mt("console");

这将确保只有一个实例,因为初始化程序只执行一次。

【讨论】:

我发现你的解决方案又快又干净 :) (如果这就是 OP 想要的) 为什么脏? 通常您希望在开始使用记录器之前对其进行配置,这种隐式初始化会使其更难正确。

以上是关于我不能在循环中使用 spdlog 记录器的主要内容,如果未能解决你的问题,请参考以下文章

如何在代码中启用/禁用 spdlog 日志记录?

带有 gtest 框架的 Spdlog 记录器无法正常工作

如何使用 spdlog 记录 pid(进程 ID)

从动态加载的库中记录

如何将 Windows 调试记录器附加到 spdlog

spdlog:无法刷新/写入文件