1.前言
最近分析了一个宏定义的妙用方法,利用宏定义来构建一个枚举类型,通过自己代码测试验证,方法可行,分享给大家。
2.源码
实验源码如下所示:
head1.h
DEF_TEST(name1)
DEF_TEST(name2)
DEF_TEST(name3)
#undef DEF_TEST
head2.h
typedef enum
{
#define DEF_TEST(name) TEST_##name,
#include "head1.h"
TEST_MAX
}def_test_t;
main.c
#include <stdio.h>
#include "head2.h"
int main(void)
{
printf("result:%d-%d-%d-%d-\r\n",TEST_name1, TEST_name2, TEST_name3, TEST_MAX);
return 0;
}
输出结果:
3.分析
源码主要的作用是生成定义一组枚举值。
#define DEF_TEST(name) TEST_##name,
这条语句宏定义DEF_TEST(name) 告诉编译器,用TEST_##name来代替,##在C语言中被称为连接符,以下是C程序设计语言中原文:
预处理运算符 ##为宏扩展提供了一种连接实际变元的手段。如果替换文本中的参数用##相连,那么参数就被实际变元替换, ##与前后的空白符被删除,并对替换后的结果重新扫描。
如:#define TEST(X,Y) X##Y,则宏调用TEST(a,b)的结果是ab。
#define DEF_TEST(name) TEST_##name,
#include “head1.h”
这个头文件里面定义了很多宏定义,均是基于#define DEF_TEST(name) TEST_##name来替换的,注意##name后面有个逗号,。这样的话,整个枚举结构展开其实就成了。
Typedef enum
{
TEST_name1,
TEST_name2,
TEST_name3,
TEST_MAX
}def_test_t;
看这个结构体,大家都明白了吧,不用多解释了吧,TEST_MAX则正好表示以上的个数了。