spdlog多个项目共用记录器
时间: 2023-09-02 12:15:50 浏览: 218
在spdlog中,可以使用`spdlog::get()`函数获取默认记录器,同时也可以使用`spdlog::create()`函数创建新的记录器。
如果多个项目需要共用同一个记录器,可以在其中一个项目中创建记录器并使用`spdlog::register_logger()`函数注册到全局的记录器列表中,然后在其他项目中使用`spdlog::get()`函数获取该记录器即可。
例如,在项目A中创建并注册记录器:
```cpp
auto logger = spdlog::create<spdlog::sinks::stdout_color_sink_mt>("my_logger");
spdlog::register_logger(logger);
```
然后在项目B中获取该记录器:
```cpp
auto logger = spdlog::get("my_logger");
logger->info("Log message from project B");
```
这样,项目B就可以共用项目A中创建的记录器了。
相关问题
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提供的线程安全日志器来实现线程安全的日志记录。
阅读全文