[C]C语言日志系统宏技巧解析

代码解释:日志标签字符串化宏

这段代码定义了一个名为 _LOG_TAG 的宏,用于将 LOG_TAG_CONST 转换为字符串形式。这在日志系统中很常见,用于为不同模块添加标识前缀。

宏结构分析

c 复制代码
#define _LOG_TAG                        STR(LOG_TAG_CONST)

这个宏包含两个关键部分:

  1. STR

    • 这是一个用于将参数转换为字符串的宏
    • 通常定义为:#define STR(x) #x,其中 # 是C语言的字符串化操作符
    • 例如,STR(FOO) 会被展开为 "FOO"
  2. LOG_TAG_CONST

    • 这是一个需要用户定义的常量,代表模块名或标签
    • 例如,在某个文件中可能会定义:#define LOG_TAG_CONST "SENSOR"

宏展开示例

假设 LOG_TAG_CONST 被定义为 "SENSOR",并且 STR 宏的实现为:

c 复制代码
#define STR(x) #x

那么:

c 复制代码
_LOG_TAG

会被展开为:

c 复制代码
"SENSOR"

这个字符串通常会作为日志前缀,例如在之前的 log_info 宏中:

c 复制代码
log_info("温度读数: %d", temp);

最终会生成类似这样的日志输出:

复制代码
[Info]: SENSOR温度读数: 25

多级字符串化技巧

在某些情况下,你可能需要对已经是宏的参数进行字符串化。例如:

c 复制代码
#define MODULE_NAME SENSOR
#define LOG_TAG_CONST MODULE_NAME

此时直接使用 STR(LOG_TAG_CONST) 会得到 "MODULE_NAME",而不是 "SENSOR"。为了解决这个问题,通常需要使用两级字符串化:

c 复制代码
#define STR(x) #x
#define XSTR(x) STR(x)  // 二级字符串化宏

#define _LOG_TAG                        XSTR(LOG_TAG_CONST)

这样,当 LOG_TAG_CONST 是另一个宏时,也能正确展开为对应的字符串。

使用建议

  1. 在每个源文件中定义 LOG_TAG_CONST

    c 复制代码
    // sensor.c
    #define LOG_TAG_CONST "SENSOR"
  2. 确保 STR 宏在使用 _LOG_TAG 之前被定义:

    c 复制代码
    #define STR(x) #x
    #define _LOG_TAG STR(LOG_TAG_CONST)
  3. 如果需要多级展开,使用 XSTR 宏:

    c 复制代码
    #define STR(x) #x
    #define XSTR(x) STR(x)
    #define _LOG_TAG XSTR(LOG_TAG_CONST)

这种设计使得日志系统更加模块化,不同的源文件可以使用不同的标签,便于调试和维护。

相关推荐
天天摸鱼的java工程师几秒前
🔧 MySQL 索引的设计原则有哪些?【原理 + 业务场景实战】
java·后端·面试
学不动CV了11 分钟前
单片机ADC采集机理层面详细分析(二)
c语言·arm开发·stm32·单片机·嵌入式硬件·开源·51单片机
学不动CV了15 分钟前
51核和ARM核单片机OTA实战解析(二)
c语言·arm开发·stm32·单片机·嵌入式硬件·51单片机
-XWB-17 分钟前
【安全漏洞】网络守门员:深入理解与应用iptables,守护Linux服务器安全
linux·服务器·网络
空影学Java18 分钟前
Day44 Java数组08 冒泡排序
java
不做无法实现的梦~25 分钟前
mid360连接机载电脑,远程桌面连接不上的情况
运维·服务器·电脑
程序员编程指南44 分钟前
Qt 与 WebService 交互开发
c语言·开发语言·c++·qt·交互
追风少年浪子彦1 小时前
mybatis-plus实体类主键生成策略
java·数据库·spring·mybatis·mybatis-plus
kura_tsuki1 小时前
[Linux入门] Linux 远程访问及控制全解析:从入门到实战
linux·服务器·安全
创码小奇客1 小时前
Talos 使用全攻略:从基础到高阶,常见问题一网打尽
java·后端·架构