关键字:#define
用途:
- 用一个字符串代替一个数字,便于理解,防止出错;
- 提取程序中经常出现的参数,便于快速修改(比如当函数中出现大量GPIO_PIN0时,当想把GPIO_PIN0修改为GPIO_PIN1时,可以使用宏定义,只需要把宏定义里的GPIO_PIN0改为GPIO_PIN1就行,不用去函数中一个一个修改GPIO_PIN0了);
#define AB 12345 //定义宏定义,新名字在左边,最后没有分号
int a = ABC; //引用宏定义,等效于int a = 12345;
关键字:typedef
用途:跟宏定义类似,将一个比较长的变量类型名换个名字,便于使用。
注意的是,宏定义可以给任何东西换名字,但ttypedef只能给变量类型换名字。
typedef unsigned char uint8_t;//定义typedef,新名字在右边,最后有分号
uint8_t a; //引用typedef,等效于unsigned char a;
其他拓展:
#undef:是用来撤销宏定义的,用法如下:
#define PI 3.141592654
.......// code
#undef PI
//下面开始 PI 就失效了
使用ifndef防止头文件被重复包含和编译:
条件指示符#ifndef检查预编译常量在前面是否已经被宏定义
- 如果在前面没有被宏定义,则条件指示符的值为真,于是从#ifndef到#endif之间的所有语句都被包含进来进行编译处理。
- 相反,如果#ifndef指示符的值为假,则它与#endif指示符之间的行将被忽略。
千万不要忽略了头件的中的#ifndef,这是一个很关键的东西。比如你有两个C文件,这两个C文件都include了同一个头文件。而编译时,这两个C文件要一同编译成一个可运行文件,这会大量的声明冲突。
这是常用格式:
#ifndef x //先测试x是否被宏定义过
#define x //如果没有宏定义下面就宏定义x并编译下面的语句
...
...
...
#endif //如果已经定义了则编译#endif后面的语句
123456
#ifndef 的命名
- 在理论上来说可以是自由命名的,但每个头文件的这个“标识”都应该是唯一的。
- 标识的命名规则一般是头文件名全大写,前后加下划线,并把文件名中的“.”也变成下划线,如:stdio.h