gpt4 book ai didi

c++ - 我不能循环使用spdlog记录器

转载 作者:行者123 更新时间:2023-12-03 07:15:46 24 4
gpt4 key购买 nike

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

#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");
这将确保只存在一个实例,因为初始化程序只执行一次。

关于c++ - 我不能循环使用spdlog记录器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64357943/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com