繁体   English   中英

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

[英]I can't use spdlog loggers in a loop

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

#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)

非常快速和肮脏的解决方法是:

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

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM