目录

一,C语言中的宏
C语言中宏定义分两种:定义常量和定义代码块,定义代码块可以将代码块当中函数使用。
语法:#define,是预处理器处理的单元实体之一。
#define定义的宏可以出现在程序的任意位置。
#define定义之后的代码都可以使用这个宏。
注意:宏定义在预处理器中处理,预处理器分不清语法错误,只有进入到编译器才能辨别语法错误。
二,宏定义常量
-
#define定义的宏常量可以直接使用
-
#define定义的宏常量本质为字面量,字面量不占用内存。
#define ERROR -1
#define PATH1 "D:\test\test.c"
#define PATH2 D:\test\test.c
#define PATH3 D:\test\
test.c
int main()
{
int err = ERROR;
char* p1 = PATH1;
char* p2 = PATH2;
char* p3 = PATH3;
}
11,12行有语法错误,能在预处理器中处理,但编译器无法通过。
11行,注意字符串可以直接以地址形式赋值给指针。
三,宏定义表达式
-
#define表达式的使用类似于函数调用。
-
#define表达式比函数更强大,但是也更容易出错(因为预处理器处理后在交给编译器编译)。
#include <stdio.h>
#define _SUM_(a, b) (a) + (b)
#define _MIN_(a, b) ((a) < (b) ? (a) : (b))
#define _DIM_(a) sizeof(a)/sizeof(*a)
int main()
{
int a = 1;
int b = 2;
int c[4] = {0};
int s1 = _SUM_(a, b);
int s2 = _SUM_(a, b) * _SUM_(a, b);
int m = _MIN_(a++, b);
int d = _DIM_(c);
printf("s1 = %d\n", s1);
printf("s2 = %d\n", s2);
printf("m = %d\n", m);
printf("d = %d\n", d);
return 0;
}
14到17行调用宏表达式均没问题,但是结果会和我们想的不一样。
15行翻译过来:(a)+(b)*(a)+(b)
16行翻译过来:((a++)<(b) ? (a++):(b))
所有15,16行反映出了宏表达式更容易出错。
注意:5行#define能定义一个计算数组大小的宏表达式,这个功能在C语言的函数中无法做到。
1,宏表达式与函数对比:
-
宏表达式使用时的参数不会进行求值和运算。
-
宏表达式没有任何的"调用"开销。而函数调用则需要参数入栈,需函数返回值。
-
宏表达式中不能出现递归语句,但可以出现循环语句。
#define _SUM_ ((n>0) ? (_SUM_(n-1)+n) : 0)
#define F(i, m) for(i=0; i<m ; i++)
1行为递归,该语法是错误的。
2行为循环,改语法正确。
-
宏定义的常量和表达式没有作用域的限制。作用域只针对变量和函数。
四,强大的内置宏

本文详细介绍了C语言中的宏定义,包括定义常量和代码块,特别强调了宏定义表达式与函数的区别,以及宏表达式可能带来的问题和优势。同时,提到了宏表达式在计算数组大小等特定场景下的独特作用,并对比了宏与函数在参数求值、开销和递归使用上的不同。

1216

被折叠的 条评论
为什么被折叠?



