在 SPDLOG 中,打印不同级别的日志(如 info
、debug
)与 WARN
的用法类似,只需替换宏和对应的级别名称即可。以下是具体示例:
1. 打印 INFO 级别日志
SPDLOG_LOGGER_INFO(GlobalLogger::getLogger(), "This is an info message from {}:{}", __FILE__, __LINE__);
2. 打印 DEBUG 级别日志
SPDLOG_LOGGER_DEBUG(GlobalLogger::getLogger(), "This is a debug message from {}:{}", __FILE__, __LINE__);
关键点说明
宏对应关系
SPDLOG 为每个日志级别提供了对应的宏:SPDLOG_LOGGER_TRACE
SPDLOG_LOGGER_DEBUG
SPDLOG_LOGGER_INFO
SPDLOG_LOGGER_WARN
SPDLOG_LOGGER_ERROR
SPDLOG_LOGGER_CRITICAL
确保 DEBUG 日志可见
默认情况下,DEBUG 级别可能被禁用。需在初始化时设置日志级别:logger->set_level(spdlog::level::debug); // 允许输出 DEBUG 及以上级别
格式化参数
支持任意数量的格式化参数(类似fmtlib
),例如:SPDLOG_LOGGER_INFO(logger, "User: {}, Score: {:.2f}", username, score);
完整示例代码
// 初始化日志器(确保已调用 GlobalLogger::init())
auto logger = GlobalLogger::getLogger();
// 打印不同级别日志
SPDLOG_LOGGER_INFO(logger, "System started at {}", std::chrono::system_clock::now());
SPDLOG_LOGGER_DEBUG(logger, "Debug data: x={}, y={}", x, y);
// WARN/ERROR 示例
if (error) {
SPDLOG_LOGGER_ERROR(logger, "Failed to open file at {}:{}", __FILE__, __LINE__);
}
注意事项
- 性能影响:频繁输出 DEBUG 日志可能影响性能,建议在生产环境中关闭 DEBUG 级别。
- 条件编译:可通过宏控制是否编译 DEBUG 日志:
#ifdef ENABLE_DEBUG_LOG
SPDLOG_LOGGER_DEBUG(logger, "Debug message...");
#endif
如果需要进一步优化或定制,可以查阅 SPDLOG官方文档。
内容由零声教学AI助手提供,问题来源于学员提问