当前位置: 首页 > article >正文

【优秀三方库研读】在 quill 开源库 LogMarcos.h 中知识点汇总及讲解

以下是LogMarcos.h中的主要知识点汇总及详细讲解:


大纲目录

  1. 编译时日志级别过滤
  2. 预处理宏与条件编译
  3. 可变参数处理技巧
  4. 格式化字符串生成
  5. 日志宏的分发机制
  6. 线程本地存储(TLS)
  7. 零成本抽象设计
  8. 动态日志级别支持
  9. 结构化日志标签
  10. 日志频率限制机制

1. 编译时日志级别过滤

核心宏QUILL_COMPILE_ACTIVE_LOG_LEVEL

  • 通过定义不同日志级别对应的数值(如QUILL_COMPILE_ACTIVE_LOG_LEVEL_TRACE_L3=0),允许在编译时完全剔除低于指定级别的日志代码。
  • 零成本:通过#if条件编译,将不需要的日志语句替换为(void)0,消除分支和对象创建。
  • 使用示例
    // 编译时仅保留WARNING及以上级别
    add_compile_definitions(-DQUILL_COMPILE_ACTIVE_LOG_LEVEL=6)
    

2. 预处理宏与条件编译

关键技巧

  • 默认值处理
    #if !defined(QUILL_COMPILE_ACTIVE_LOG_LEVEL)#define QUILL_COMPILE_ACTIVE_LOG_LEVEL -1  // 默认启用所有级别
    #endif
    
  • 函数名获取
    #define QUILL_FUNCTION_NAME __FUNCTION__  // 使用编译器内置宏
    
  • 空语句替换
    #define QUILL_LOG_TRACE_L3(
http://www.lryc.cn/news/2384101.html

相关文章:

  • jvm安全点(五)openjdk17 c++源码垃圾回收之安全点阻塞状态线程在安全点同步中无需调用block函数的详细流程解析
  • C++ 中的 **常变量** 与 **宏变量** 比较
  • 【C++】控制台小游戏
  • 配合本专栏前端文章对应的后端文章——从模拟到展示:一步步搭建传感器数据交互系统
  • React中常用的钩子函数:
  • springboot IOC
  • java面试每日一背 day2
  • Ajax01-基础
  • (37)服务器增加ipv6配置方法
  • 生成树协议(STP)配置详解:避免网络环路的最佳实践
  • 面向 C 语言项目的系统化重构实战指南
  • 网络层——蚂蚁和信鸽的关系VS路由原理和相关配置
  • Python Pandas库简介及常见用法
  • 第十六届蓝桥杯复盘
  • 【已解决】HBuilder X编辑器在外接显示器或者4K显示器怎么界面变的好小问题
  • 直线型绝对值位移传感器:精准测量的科技利刃
  • 解决服务器重装之后vscode Remote-SSH无法连接的问题
  • AI 招聘系统科普:如何辨别真智能与伪自动化
  • Ansible模块——管理100台Linux的最佳实践
  • 从0开始学习大模型--Day09--langchain初步使用实战
  • C++中的菱形继承问题
  • 订单越来越到导致接口列表查询数据缓慢解决思路
  • word格式相关问题
  • 网络-MOXA设备基本操作
  • 飞桨paddle import fluid报错【已解决】
  • 测试工程师要如何开展单元测试
  • IPv4 地址嵌入 IPv6 的前缀转换方式详解
  • 野火鲁班猫(arrch64架构debian)从零实现用MobileFaceNet算法进行实时人脸识别(三)用yolov5-face算法实现人脸检测
  • IS-IS 中间系统到中间系统
  • 【图像生成大模型】HunyuanVideo:大规模视频生成模型的系统性框架