spdlog找不到spdlog/details/shared_ptr.h
时间: 2023-08-01 17:08:21 浏览: 127
如果你的编译器找不到"spdlog/details/shared_ptr.h"这个头文件,有可能是因为你的spdlog版本较旧,或者你的安装方式有误。
可以尝试以下几步解决该问题:
1. 使用最新版本的spdlog库,可以从官方GitHub仓库下载最新代码并编译安装。
2. 确认你的spdlog安装路径正确,并且已经将该路径添加到了编译器的搜索路径中。
3. 将"spdlog/details/shared_ptr.h"文件所在路径手动添加到编译器的搜索路径中。
如果以上方法都不能解决问题,建议重新安装spdlog库,并确保按照正确的步骤进行安装。
相关问题
#ifndef MYSPDLOG_H #define MYSPDLOG_H #include <fstream> #include <iostream> #define SPDLOG_HEADER_ONLY #define SPDLOG_ACTIVE_LEVEL SPDLOG_LEVEL_DEBUG #include "spdlog/spdlog.h" #include "spdlog/logger.h" #include "spdlog/sinks/basic_file_sink.h" #include "spdlog/sinks/rotating_file_sink.h" #include "spdlog/sinks/stdout_color_sinks.h" #include "spdlog/sinks/daily_file_sink.h" class MySpdlog { public: static MySpdlog*getInstace() { static MySpdlog MySpdlogStatic; return &MySpdlogStatic; } int init() { std::string formatStr="%Y-%m-%dT%H:%M:%S.%e[%l][%s:%#][%!]%v"; // auto myLogger1 = std::make_shared<spdlog::sinks::rotating_file_sink_mt>("spdlog", "logs/myspdlog.log", 1024 * 1024 * 10, 10); // auto myLogger1 = std::make_shared<spdlog::sinks::daily_file_sink>("spdlog", "logs/log.txt", 0, 0); myLogger1 = spdlog::daily_logger_mt("spdlog", "logs/log.txt", 0, 0); // myLogger1 = spdlog::rotating_logger_mt("spdlog", "logs/myspdlog.log", 1024 * 1024 * 10, 10); spdlog::set_default_logger(myLogger1); myLogger1->set_level(spdlog::level::debug); myLogger1->set_pattern(formatStr); myLogger2 = spdlog::stdout_color_mt("baseLogger2"); spdlog::set_default_logger(myLogger2); myLogger2->set_level(spdlog::level::debug); myLogger2->set_pattern(formatStr); return 0; } void uninit() { } static std::shared_ptr<spdlog::logger> myLogger1; static std::shared_ptr<spdlog::logger> myLogger2; private: MySpdlog() {} ~MySpdlog() {} }; #define SPLOG_INIT() MySpdlog::getInstace()->init() #define SPLOG_UNINIT() MySpdlog::getInstace()->uninit() #define SPLOG_DEBUG(...) do {SPDLOG_LOGGER_DEBUG(MySpdlog::getInstace()->myLogger1, __VA_ARGS__);\ SPDLOG_LOGGER_DEBUG(MySpdlog::getInstace()->myLogger2, __VA_ARGS__);}while(0) #define SPLOG_INFO(...) do {SPDLOG_LOGGER_INFO(MySpdlog::getInstace()->myLogger1, __VA_ARGS__);\ SPDLOG_LOGGER_INFO(MySpdlog::getInstace()->myLogger2, __VA_ARGS__); }while(0) #define SPLOG_ERROR(...) do {SPDLOG_LOGGER_ERROR(MySpdlog::getInstace()->myLogger1, __VA_ARGS__);\ SPDLOG_LOGGER_ERROR(MySpdlog::getInstace()->myLogger2, __VA_ARGS__);}while(0) #define SPDLOG_CLRAR(a) do{std::fstream fout((a),std::ios::out|std::ios::trunc);fout.close();}while(0); #endif // MYSPDLOG_H这样写完打印的log不是实时打印的
可以尝试使用flush_on()函数,将日志输出立即刷新到文件中,达到实时打印的效果。例如,在MySpdlog::init()函数中加入如下代码:
myLogger1->flush_on(spdlog::level::debug);
myLogger2->flush_on(spdlog::level::debug);
这样,在SPLOG_DEBUG()宏中打印日志时,日志将会立即刷新到文件中。另外,也可以使用set_pattern()函数来设置日志输出的格式。
/workspace/S2/qt/Deploy_infer/MySpdlog.h:35: error: could not convert 'myLogger1' from 'shared_ptr<spdlog::sinks::rotating_file_sink<std::mutex>>' to 'shared_ptr<spdlog::logger>' 35 | spdlog::set_default_logger(myLogger1); | ^~~~~~~~~ | | | shared_ptr<spdlog::sinks::rotating_file_sink<std::mutex>>
这个错误是因为 `spdlog::set_default_logger` 函数需要接受一个 `shared_ptr<spdlog::logger>` 类型的参数,而你传入了一个 `shared_ptr<spdlog::sinks::rotating_file_sink<std::mutex>>` 类型的参数。
这是因为 `spdlog::sinks::rotating_file_sink<std::mutex>` 是一个日志输出 sink 类型,而 `spdlog::logger` 是一个日志记录器类型。你需要在创建日志记录器时使用 `spdlog::logger` 类型,而不是 `spdlog::sinks::rotating_file_sink<std::mutex>` 类型。
你可以使用以下代码来创建一个日志记录器:
```cpp
auto myLogger1 = std::make_shared<spdlog::logger>("my_logger", std::make_shared<spdlog::sinks::rotating_file_sink_mt>("logs/log.txt", 1024 * 1024 * 5, 3));
```
这个代码会创建一个名为 "my_logger" 的日志记录器,它将日志输出到 `logs/log.txt` 文件中,日志文件大小限制为 5 MB,最多保留 3 个历史日志文件。然后,你可以将这个日志记录器设置为默认记录器:
```cpp
spdlog::set_default_logger(myLogger1);
```
这样就可以了。如果你有任何疑问,请随时问我。
阅读全文