#include <stdio.h> #define N 100 int main(){ int sum = 20 + N; printf("%d\n", sum); return 0; }运行结果:
int sum = 20 + N
,N
被100
代替了。#define N 100
就是宏定义,N
为宏名,100
是宏的内容(宏所表示的字符串)。在预处理阶段,对程序中所有出现的“宏名”,预处理器都会用宏定义中的字符串去代换,这称为“宏替换”或“宏展开”。#define
完成的,宏替换是由预处理程序完成的。#define 宏名 字符串
#
表示这是一条预处理命令,所有的预处理命令都以 # 开头。宏名
是标识符的一种,命名规则和变量相同。字符串
可以是数字、表达式、if 语句、函数等。
程序中反复使用的表达式就可以使用宏定义,例如:
#define M (n*n+3*n)它的作用是指定标识符
M
来表示(y*y+3*y)
这个表达式。在编写代码时,所有出现 (y*y+3*y) 的地方都可以用 M 来表示,而对源程序编译时,将先由预处理程序进行宏代替,即用 (y*y+3*y) 去替换所有的宏名 M,然后再进行编译。#include <stdio.h> #define M (n*n+3*n) int main(){ int sum, n; printf("Input a number: "); scanf("%d", &n); sum = 3*M+4*M+5*M; printf("sum=%d\n", sum); return 0; }运行结果:
sum=3*(n*n+3*n)+4*(n*n+3*n)+5*(n*n+3*n);需要注意的是,在宏定义中表达式
(n*n+3*n)
两边的括号不能少,否则在宏展开以后可能会产生歧义。下面是一个反面的例子:
#difine M n*n+3*n在宏展开后将得到下述语句:
s=3*n*n+3*n+4*n*n+3*n+5*n*n+3*n;这相当于:
3n2+3n+4n2+3n+5n2+3n
这显然是不正确的。所以进行宏定义时要注意,应该保证在宏替换之后不发生歧义。#undef
命令。例如:
#define PI 3.14159 int main(){ // Code return 0; } #undef PI void func(){ // Code }表示 PI 只在 main() 函数中有效,在 func() 中无效。
#include <stdio.h> #define OK 100 int main(){ printf("OK\n"); return 0; }运行结果:
#define PI 3.1415926 #define S PI*y*y /* PI是已定义的宏名*/对语句:
printf("%f", S);在宏代换后变为:
printf("%f", 3.1415926*y*y);
#define UINT unsigned int在程序中可用 UINT 作变量说明:
UINT a, b;应注意用宏定义表示数据类型和用 typedef 定义数据说明符的区别。宏定义只是简单的字符串替换,由预处理器来处理;而 typedef 是在编译阶段由编译器处理的,它并不是简单的字符串替换,而给原有的数据类型起一个新的名字,将它作为一种新的数据类型。
#define PIN1 int * typedef int *PIN2; //也可以写作typedef int (*PIN2);从形式上看这两者相似, 但在实际使用中却不相同。
PIN1 a, b;在宏代换后变成:
int * a, b;表示 a 是指向整型的指针变量,而 b 是整型变量。然而:
PIN2 a,b;表示 a、b 都是指向整型的指针变量。因为 PIN2 是一个新的、完整的数据类型。由这个例子可见,宏定义虽然也可表示数据类型, 但毕竟只是简单的字符串替换。在使用时要格外小心,以避出错。
本文链接:http://task.lmcjl.com/news/6616.html