news 2026/4/18 14:46:07

即时通讯项目--(2)spdlog二次封装

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
即时通讯项目--(2)spdlog二次封装

spdlog的二次封装:
原因:
1.避免单例的锁冲突,因此直接创建全局的线程安全的日志器进行使用
2.因为日志输出没有文件名行号,因此使用宏进行二次封装输出日志的文件名和行号
3.封装出一个初始化接口,便于使用:调试模式则输出到标准输出,否则输出到文件中
思想:
封装出一个全局接口,用户进行日志器的创建与初始化
1.初始化接口接收一个参数:运行模式-bool
2.初始化接口接收一个参数:输出文件名 -- 用于发布模式
3.初始化接口接收一个参数:输出日志等级 -- 用于发布模式
对日志输出的接口,进行宏的封装,加入文件名行号的输出

#pragma once #include <spdlog/spdlog.h> #include <spdlog/sinks/stdout_color_sinks.h> #include <spdlog/sinks/basic_file_sink.h> #include <spdlog/async.h> #include <iostream> // mode - 运行模式: true-发布模式; false调试模式 namespace im{ std::shared_ptr<spdlog::logger> g_default_logger; void init_logger(bool mode,const std::string& file,int32_t level){ if(mode == false){ // 调试模式:彩色控制台输出,最低日志等级(输出所有日志) g_default_logger = spdlog::stdout_color_mt("default-logger"); g_default_logger->set_level(spdlog::level::level_enum::trace); g_default_logger->flush_on(spdlog::level::level_enum::trace); } else{ // 发布模式:文件输出,按参数设置日志等级 g_default_logger = spdlog::basic_logger_mt("default-logger",file); g_default_logger->set_level((spdlog::level::level_enum)level); g_default_logger->flush_on((spdlog::level::level_enum)level); } // 所有模式统一设置日志输出格式 g_default_logger->set_pattern("[%n][%H:%M:%S][%t][%-8l]%v"); #define LOG_TRACE(format, ...) im::g_default_logger->trace(std::string("[{}:{}] ") + format, __FILE__, __LINE__, ##__VA_ARGS__) #define LOG_DEBUG(format, ...) im::g_default_logger->debug(std::string("[{}:{}] ") + format, __FILE__, __LINE__, ##__VA_ARGS__) #define LOG_INFO(format, ...) im::g_default_logger->info(std::string("[{}:{}] ") + format, __FILE__, __LINE__, ##__VA_ARGS__) #define LOG_WARN(format, ...) im::g_default_logger->warn(std::string("[{}:{}] ") + format, __FILE__, __LINE__, ##__VA_ARGS__) #define LOG_ERROR(format, ...) im::g_default_logger->error(std::string("[{}:{}] ") + format, __FILE__, __LINE__, ##__VA_ARGS__) #define LOG_FATAL(format, ...) im::g_default_logger->critical(std::string("[{}:{}] ") + format, __FILE__, __LINE__, ##__VA_ARGS__) } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 5:37:40

革新性全平台图像与漫画阅读器:重新定义数字阅读体验

革新性全平台图像与漫画阅读器&#xff1a;重新定义数字阅读体验 【免费下载链接】quickviewer A image/comic viewer application for Windows, Mac and Linux, it can show images very fast 项目地址: https://gitcode.com/gh_mirrors/qu/quickviewer 在数字阅读日益…

作者头像 李华
网站建设 2026/4/17 13:03:01

如何高效使用Qwen-Image-2512?内置工作流调用指南

如何高效使用Qwen-Image-2512&#xff1f;内置工作流调用指南 你是不是也遇到过这样的情况&#xff1a;下载了一个看起来很厉害的图片生成模型&#xff0c;结果打开ComfyUI界面&#xff0c;面对密密麻麻的节点和空白画布&#xff0c;完全不知道从哪下手&#xff1f;点开几个内…

作者头像 李华
网站建设 2026/4/18 0:40:55

分布式数据库监控实战:从问题诊断到落地实践

分布式数据库监控实战&#xff1a;从问题诊断到落地实践 【免费下载链接】rqlite rqlite/rqlite: 这是一个用于构建高可用、分布式SQLite数据库的工具。适合用于需要构建高可用、分布式SQLite数据库的场景。特点&#xff1a;易于使用&#xff0c;支持多种数据库操作&#xff0c…

作者头像 李华
网站建设 2026/4/18 3:28:29

5个维度解析高性能Node.js版本管理:从环境配置到企业级实践

5个维度解析高性能Node.js版本管理&#xff1a;从环境配置到企业级实践 【免费下载链接】fnm &#x1f680; Fast and simple Node.js version manager, built in Rust 项目地址: https://gitcode.com/gh_mirrors/fn/fnm 在现代前端开发中&#xff0c;Node.js版本管理工…

作者头像 李华
网站建设 2026/4/18 3:29:20

企业级文件在线预览解决方案:技术原理与场景落地实践

企业级文件在线预览解决方案&#xff1a;技术原理与场景落地实践 【免费下载链接】kkFileView Universal File Online Preview Project based on Spring-Boot 项目地址: https://gitcode.com/GitHub_Trending/kk/kkFileView 在数字化办公环境中&#xff0c;企业常常面临…

作者头像 李华