直接调用即可。如下示例:
#include<stdio.h> #define sum(b,c){int d=0;d=b+c;printf("两者的和:%d\n",d);} int main() { int x=0,y=0; scanf("%d%d",&x,&y); sum (x,y); return 0; }
测试通过:
#include<stdio.h>
#include<stdlib.h>
#define sum(b,c){int d=0;d=b+c;printf("两者的和:%d\n",d);}
int main()
{
int x=0,y=0;
scanf("%d%d",&x,&y);
sum (x,y);
system("pause");
return 0;
}
测试代码2:通过
#include <stdio.h>
#include <stdlib.h>
#define transit(a, b, c, type) { type t=a;a=b;b=c;c=t;}
int main()
{
int a=1;
int b=2;
int c=3;
printf("a=%d, b=%d, c=%d\n", a, b, c);
transit(a, b, c, int);
printf("a=%d, b=%d, c=%d\n", a, b ,c);
system("pause");
return 1;
}
使用宏函数或者宏函数时,注意如下几点:
(1)宏函数的参数没有类型,预处理器只负责做形式上的替换,而不做参数类型检查,所以传参时要格外小心。
(2)宏函数定义要注意格式,尤其是括号。
如果上面的宏函数写成 #define MAX(a, b) (a>b?a:b),省去内层括号,则宏展开就成了k = (i&0x0f>j&0x0f?i&0x0f:j&0x0f),运算的优先级就错了。同样道理,这个宏定义的外层括号也是不能省的。若函数中是宏替换为 ++MAX(a,b),则宏展开就成了 ++(a)>(b)?(a):(b),运算优先级也是错了。
(3)宏函数往往会导致较低的代码执行效率。
int a[]={9,3,5,2,1,0,8,7,6,4}; int max(n) { return n==0?a[0]:MAX(a[n],max(n-1)); } int main() { max(9); return 0; }
若是普通函数,则通过递归,可取的最大值,时间复杂度为O(n)。但若是宏函数,则宏展开为( a[n]>max(n-1)?a[n]:max(n-1) ),其中max(n-1)被调用了两遍,这样依此递归下去,时间复杂度会很高。