spdlog 日志库部分源码说明

前言

针对 网络上spdlog日志库目前存在的使用方式固定,不能发挥这个库本身应有价值的情况,这里对一些支持场景进行说明,以供初学者省去阅读源码的时间,直接上手使用

涉及源码

在说明过程中使用spdlog库自身提供的使用说明示例,进行介绍。
源码路径:spdlog-1.x/example/example.cpp

让日志文件可以每日定时切换 daily_logger_mt()

template<typename Factory = spdlog::synchronous_factory>
inline std::shared_ptr<logger> daily_logger_mt(const std::string &logger_name, const filename_t &filename, int hour = 0, int minute = 0,
    bool truncate = false, uint16_t max_files = 0, const file_event_handlers &event_handlers = {})
{
    return Factory::template create<sinks::daily_file_sink_mt>(logger_name, filename, hour, minute, truncate, max_files, event_handlers);
}

介绍:涉及文件:/usr/local/include/spdlog/sinks/daily_file_sink.h 这里是已经安装完成之后的路径。

接口介绍:

// 使用给定的工厂类创建一个每日日志记录器
// 如果没有提供工厂类,则默认为spdlog::synchronous_factory
template<typename Factory = spdlog::synchronous_factory>
inline std::shared_ptr<logger> daily_logger_mt(
    const std::string &logger_name,     // 日志记录器的名称
    const filename_t &filename,         // 每日日志文件的名称模式
    int hour = 0,                        // 每天轮换日志文件的时间(小时),默认为0
    int minute = 0,                      // 每天轮换日志文件的时间(分钟),默认为0
    bool truncate = false,               // 如果为true,当日志文件存在时,将其截断;否则,追加到现有文件,默认为false
    uint16_t max_files = 0,              // 保存的最大日志文件数量,默认为0(无限制)
    const file_event_handlers &event_handlers = {} // 文件事件处理器
)
{
    // 使用提供的工厂类创建一个每日日志记录器,并返回其共享指针
    return Factory::template create<sinks::daily_file_sink_mt>(logger_name, filename, hour, minute, truncate, max_files, event_handlers);
}

使用方式:

#include "spdlog/sinks/daily_file_sink.h"  // 如果以自己解决方案安装时使用
// #include <spdlog/sinks/daily_file_sink.h> // 如果以默认方式安装时使用
void daily_example()
{
    // Create a daily logger - a new file is created every day on 2:30am.
    auto daily_logger = spdlog::daily_logger_mt("daily_logger", "logs/daily.txt", 2, 30);
}

分享一个有趣的 学习链接:https://xxetb.xet.tech/s/HY8za

相关推荐

  1. spdlog 日志部分说明

    2024-04-22 14:58:05       19 阅读
  2. spdlog学习

    2024-04-22 14:58:05       38 阅读
  3. spdlog解析

    2024-04-22 14:58:05       9 阅读
  4. 05_c/c++开源 spdlog日志

    2024-04-22 14:58:05       13 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-22 14:58:05       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-22 14:58:05       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-22 14:58:05       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-22 14:58:05       20 阅读

热门阅读

  1. 软件测试 -- 自动化测试(Selenium)

    2024-04-22 14:58:05       18 阅读
  2. 2023-2024年人形机器人行业报告合集(精选397份)

    2024-04-22 14:58:05       15 阅读
  3. pcb的几种常见认证

    2024-04-22 14:58:05       14 阅读
  4. uniapp 页面跳转通信上下级页面互传

    2024-04-22 14:58:05       15 阅读
  5. 一文了解什么是RESTful风格

    2024-04-22 14:58:05       13 阅读
  6. SQL Server详细使用教程

    2024-04-22 14:58:05       16 阅读
  7. js实现快速拖拽(定时器版本)

    2024-04-22 14:58:05       18 阅读
  8. Flink CDC 整库 / 多表同步至 Kafka 方案(附源码)

    2024-04-22 14:58:05       14 阅读
  9. 从事数据分析相关工作技术总结

    2024-04-22 14:58:05       13 阅读
  10. FFT快速傅里叶变换音频分析

    2024-04-22 14:58:05       19 阅读
  11. 基于单片机雨天自动关窗器的设计

    2024-04-22 14:58:05       15 阅读
  12. 基础矩阵和本质矩阵

    2024-04-22 14:58:05       15 阅读
  13. 水气表CJ/T188协议学习及实例

    2024-04-22 14:58:05       12 阅读
  14. 基于springboot的教学资源库源码数据库

    2024-04-22 14:58:05       14 阅读
  15. flink mysql数据表同步SQL CDC

    2024-04-22 14:58:05       12 阅读