spdlog是C++中高效线程安全的日志库,支持异步、多输出和自定义格式。1. 通过vcpkg或源码集成,头文件仅需包含即可使用。2. 基础用法包括info、warn、error等日志级别,默认需启用debug模式。3. 使用basic_logger_mt将日志写入文件,确保目录存在。4. 组合stdout_color_sinks和file_sink实现控制台与文件双输出。5. 异步日志需初始化线程池,提升高并发性能。6. 自定义格式通过set_pattern设置时间、级别、内容等占位符。7. 最佳实践建议统一配置、命名logger、生产环境用异步、合理轮转文件。

在C++项目中实现高效、线程安全且易于使用的日志功能,spdlog 是一个非常受欢迎的选择。它是一个基于现代C++(C++11及以上)的高性能日志库,支持异步日志、多线程安全、多种日志格式和输出目标(控制台、文件等),并且使用简单。
1. 安装与集成 spdlog
spdlog 是一个头文件-only 的库,因此集成非常方便,无需编译。
方法一:通过 vcpkg 安装vcpkg install spdlog
登录后复制
方法二:直接下载源码- 从 GitHub 下载:https://github.com/gabime/spdlog
- 将
include/spdlog目录复制到你的项目 include 路径中 - 在代码中包含即可使用
add_subdirectory(vendor/spdlog) target_link_libraries(your_target spdlog)
登录后复制
2. 快速开始:基本日志输出
以下是一个简单的例子,展示如何使用 spdlog 输出日志到控制台:
#include <spdlog/spdlog.h>
int main() {
spdlog::info("这是一条信息日志");
spdlog::warn("这是一个警告");
spdlog::error("这是一个错误");
spdlog::debug("调试信息(需启用调试模式)");
return 0;
}登录后复制
默认情况下,debug 级别的日志不会显示,需要设置日志级别:
立即学习“C++免费学习笔记(深入)”;
spdlog::set_level(spdlog::level::debug); // 启用 debug 级别
登录后复制
3. 使用文件日志记录
将日志写入文件是常见需求。spdlog 提供了 basic_logger_mt 来创建线程安全的文件日志器:
#include <spdlog/sinks/basic_file_sink.h>
auto file_logger = spdlog::basic_logger_mt("file_logger", "logs/app.log");
file_logger->info("这条日志会写入文件");
file_logger->error("出错啦:无法打开文件");登录后复制
确保 logs/ 目录存在,否则会抛出异常。
4. 同时输出到控制台和文件
可以组合多个 sink,实现日志同时输出到控制台和文件:
标签: git github app ai c++ 性能瓶颈 red asic
还木有评论哦,快来抢沙发吧~