非常规的宏技巧来减少重复,但牺牲了可读性。我来拆解它的工作原理、问题所在,并提供更科学的写法。
一、代码工作原理详解
这段代码的核心是用宏元编程实现两个功能:
自动生成枚举值:通过 REC_SERVICE_TAB 宏定义一系列服务函数码(如 FC_REC_REG_RSPON=0x81)
自动生成有效性检查逻辑:在 IsRecFuncCodeValid 函数中用 switch 自动展开所有有效码的判断分支
关键宏展开步骤:
定义服务函数码表:
c
运行
#define REC_SERVICE_TAB
REC_FUNC(FC_REC_REG_RSPON, 0X81,RecRegRespone)
REC_FUNC(FC_REC_REG_REQ, 0X82,RecRegRequest)
// 更多…
生成枚举类型:
c
运行
typedef enum {
#define REC_FUNC(codeName,codeValue,recfunc) codeName,
REC_SERVICE_TAB
#undef REC_FUNC
FC_REC_INVALID = FC_INVALID
} REC_SERVICE_FUNC_CODE;
展开后等价于:
c
运行
typedef enum {
FC_REC_REG_RSPON,
FC_REC_REG_REQ,
// 更多…
FC_REC_INVALID = FC_INVALID
} REC_SERVICE_FUNC_CODE;
生成有效性检查函数:
c
运行
uint8_t IsRecFu