spdlog多个项目共用记录器
时间: 2023-09-02 09:15:56 浏览: 426
可以通过使用`spdlog::set_default_logger`函数来设置全局默认记录器。在不同的项目中,可以使用相同的名称来获取同一个记录器实例,并在不同的模块中使用该实例来记录日志。
例如,在项目A中,可以使用以下代码设置默认记录器:
```c++
auto logger = spdlog::stdout_logger_mt("my_logger");
spdlog::set_default_logger(logger);
```
在项目B中,可以使用以下代码来获取相同的记录器实例:
```c++
auto logger = spdlog::get("my_logger");
```
这样,在不同的项目中,就可以使用相同的记录器实例来记录日志。
相关问题
spdlog多个工程共用记录器
可以将记录器定义为全局变量,然后在多个工程中都引用该记录器即可。
例如,在一个名为`my_logger.h`的头文件中定义记录器:
```cpp
#pragma once
#include <spdlog/spdlog.h>
namespace my_logger
{
inline std::shared_ptr<spdlog::logger> logger;
inline void init()
{
logger = spdlog::stdout_color_mt("my_logger");
}
}
```
然后在每个使用该记录器的工程中都包含该头文件即可:
```cpp
#include "my_logger.h"
int main()
{
my_logger::init();
my_logger::logger->info("Hello, world!");
return 0;
}
```
这样,不同的工程中使用`my_logger::logger`都是同一个记录器。
spdlog多个工程共用一个记录器
可以使用spdlog的全局日志器来实现多个工程共用一个记录器。
在一个工程中,可以创建一个全局日志器,并将其设置为所有其他工程的默认日志器。这样,所有的日志信息都会被记录到同一个日志文件中。
示例代码:
```c++
#include <spdlog/spdlog.h>
int main()
{
// 创建全局日志器
auto logger = spdlog::basic_logger_mt("global_logger", "log.txt");
// 将全局日志器设置为默认日志器
spdlog::set_default_logger(logger);
// 在其他工程中,可以通过以下代码获取默认日志器
auto logger = spdlog::default_logger();
}
```
在其他工程中,可以通过spdlog::default_logger()函数获取默认日志器,即上面创建的全局日志器。这样,所有的日志信息都会被记录到同一个日志文件中。
需要注意的是,在多线程环境中使用全局日志器时,需要进行线程同步操作,以避免竞争条件的发生。可以使用spdlog提供的线程安全日志器来实现线程安全的日志记录。
阅读全文