宏定义的规则 :在预处理阶段由预处理器进行替换,这个替换是原封不动的替换
宏定义替换会递归进行,知道替换出来的值不再是一个宏
宏定义分为三部分: #define 宏名 剩下的部分
#define GGG (36524243012) //可行,可是数字太大 默认为int类型
#define GGG (36524243012UL) //转成无符号数字
带参宏和带参函数的区别(宏定义的缺陷)
宏定义是在预处理期间处理的,而函数是在编译期间处理的。
宏定义最终是在调用宏的地方把宏体原地展开,而函数是在调用函数处跳转到函数中去执行,执行完后再跳转回来
#include <stdio.h>
#define MAX(a,b) ((a)>(b) ? (a):(b))
int max(int a,int b)
{
if(a>b)
return a;
else
return b;
}
int main(void)
{
int a=3,b = 5,c = 0;
c = MAX(a,b);
printf("%d\n",c);
return 0;
}
内联函数和inline关键字
内联函数通过函数定义前加inline关键字实现
内联函数本质上是函数,所以有函数的有点(内联函数是编译器负责处理的,编译器可以帮我们做参数的静态类型检查),但是他说同时有带参宏的有点(不用调用开销,而是原地展开)
当我们函数内函数体很短的时候,我们有希望利用编译器的参数类型检查来拍错,我们还希望没有调用开销,所以最适合使用内联函数
宏定义来实现条件编译(#define #undef #ifdef)
#include<stdio.h>
#define DEBUG
#undef DEBUG //把上面符号去掉
#ifdef DEBUG //如果上面定义了DEBUG
#define debug(x) printf(x) //执行这个宏定义
#else //否则执行下面宏定义
#define debug(x)
#endif