ZBLOG

SPDLOG_LOGGER_WARN(GlobalLogger::getLogger(), "This is a warning from {}:{}", __FILE__, __LINE__); 如果要打印info和debug呢?

在 SPDLOG 中,打印不同级别的日志(如 infodebug)与 WARN 的用法类似,只需替换宏和对应的级别名称即可。以下是具体示例:


1. 打印 INFO 级别日志

  1. SPDLOG_LOGGER_INFO(GlobalLogger::getLogger(), "This is an info message from {}:{}", __FILE__, __LINE__);

2. 打印 DEBUG 级别日志

  1. SPDLOG_LOGGER_DEBUG(GlobalLogger::getLogger(), "This is a debug message from {}:{}", __FILE__, __LINE__);

关键点说明

  1. 宏对应关系
    SPDLOG 为每个日志级别提供了对应的宏:

    • SPDLOG_LOGGER_TRACE
    • SPDLOG_LOGGER_DEBUG
    • SPDLOG_LOGGER_INFO
    • SPDLOG_LOGGER_WARN
    • SPDLOG_LOGGER_ERROR
    • SPDLOG_LOGGER_CRITICAL
  2. 确保 DEBUG 日志可见
    默认情况下,DEBUG 级别可能被禁用。需在初始化时设置日志级别:

    1. logger->set_level(spdlog::level::debug); // 允许输出 DEBUG 及以上级别
  3. 格式化参数
    支持任意数量的格式化参数(类似 fmtlib),例如:

    1. SPDLOG_LOGGER_INFO(logger, "User: {}, Score: {:.2f}", username, score);

完整示例代码

  1. // 初始化日志器(确保已调用 GlobalLogger::init())
  2. auto logger = GlobalLogger::getLogger();
  3. // 打印不同级别日志
  4. SPDLOG_LOGGER_INFO(logger, "System started at {}", std::chrono::system_clock::now());
  5. SPDLOG_LOGGER_DEBUG(logger, "Debug data: x={}, y={}", x, y);
  6. // WARN/ERROR 示例
  7. if (error) {
  8. SPDLOG_LOGGER_ERROR(logger, "Failed to open file at {}:{}", __FILE__, __LINE__);
  9. }

注意事项

  • 性能影响:频繁输出 DEBUG 日志可能影响性能,建议在生产环境中关闭 DEBUG 级别。
  • 条件编译:可通过宏控制是否编译 DEBUG 日志:
    1. #ifdef ENABLE_DEBUG_LOG
    2. SPDLOG_LOGGER_DEBUG(logger, "Debug message...");
    3. #endif

如果需要进一步优化或定制,可以查阅 SPDLOG官方文档


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=23310

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?