由数组作为函数参数传递时,会失去其数组特性,也就是无法使用sizeof()函数计算出数组的大小,比如我们写一个排序函数,排序时我们不仅需要知道数组的首地址,还需要知道数组的大小,但是仅仅把数组名作为参数传递时,无法得知其数组大小,这时我们的函数就需要传递第二个参数,也就是数组的大小,于是函数就要写成Sort(int *a,int size).但宏函数就可以解决这个问题。
例如
#include"stdio.h"
#define InsertSort(a)
{
int n=sizeof(a)/sizeof(a[0]);
for(int i=1; i
通过定义一个宏来实现数组的排序功能,非常巧妙。
复习一下宏的相关知识:
相关作用符
①换行符 ""
我们定义宏语句或者宏函数时不可能总是一条语句呀,那要是有很多条语句时怎么办?都写在一行吗?这样显然代码就不美观,可读性不好,所以有多条语句时,我们就在每行末尾(除了最后一行)加上"",代表换行的意思。
②字符串化符 "#"
"#"是“字符串化”的意思,将出现在宏定义中的#是把跟在后面的参数转换成一个字符串。
③片段连接符"##"
“##”是一种分隔连接方式,它的作用是先分隔,然后进行强制连接。在普通的宏定义中,预处理器一般把空格解释成分段标志,对于每一段和前面比较,相同的就被替换。但是这样做的结果是,被替换段之间存在一些空格。如果我们不希望出现这些空格,就可以通过添加一些##来替代空格。
除了数组传递,还有一个类型传递,也十分有用。
类型传递
我们知道函数虽然可以传递参数,但是却不能把类型作为参数传递,有时我们为了实现函数的复用性,就要使用STL模板,但是我们这个时候还有另外一种选择,就是写成宏函数
例:
一个开辟内存的函数
#define Malloc(type,size) (type*)malloc(sizeof(type)*size)
这个时候,我们只有把类型,容量作为参数传递进行,就可以开辟各种类型的内存了
int *p=Malloc(int,100); //开辟int类型的内存
char *q=Malloc(char,100); //开辟字符类型的内存
C语言中宏的灵活应用是写出来各种看不懂代码的来源,也是程序员秀编程技巧的好地方。



