1、操作优先级导致的问题,通常是因为没有在宏参数加上()来强制优先导致
2、多余的;号,宏要考虑作为表达式的形式调用,因此不能添加;号
3、如果宏参数是函数的话多次调用此函数,对与这个问题可以在定义宏时声明临时变量来处理,注意要用({})包含宏体
4、Java中一些特殊写法导致宏解析出错的如传入参数是包含初始化列表的数组,宏会根据,来分割宏参数导致最终结果出错。
5、对于Java中函数重载的情况,可以使用变参宏,但是注意对应的cpp是否支持,因为这是c99才加入进来的。
这个是变参宏的实例#define myprintf(templt,...) printf(templt,##__VA_ARGS__)照着写就是了
以下这个代码包含了主要的用法(简单的我忽略了)
#include <stdio.h>
#include <stdlib.h>
#define WARN_IF(EXP) /
do{ /
if((EXP)) /
printf("WARNING/t" #EXP"/n"); /
}while(0)
struct command{char * name;void (*function) (void);};
#define COMMAND(NAME) { NAME, NAME ## _command }//注意##之后不一定要是宏参数,只要是Token就可以了
char quit[2];
void quit_command(){}
char help[2];
void help_command(){}
struct command commands[] =
{
COMMAND(quit),
COMMAND(help)
};
#define LINK_MULTIPLE(a,b,c,d) a##_##b##_##c##_##d//用来产生company,type,project一系列名字集合所产生的一个独特变量
#define myprintf(templt,...) printf(templt,##__VA_ARGS__)
#define min(X,Y) ({/
typeof (X) x_ = (X);/
typeof (Y) y_ = (Y);/
(x_ < y_) ? x_ : y_; })//({...})的作用是将内部的几条语句中最后一条的值返回,它也允许在内部声明变量(因为它通过大括号组成了一个局部Scope)
int main()
{
WARN_IF(1);
int a=1,b=1,c=1,d=1;
a +=1;
b +=2;
c +=3;
d +=4;
myprintf("abscddsdada %d,%d,%d,%d/n",a,b,c,d);
myprintf("Error/n");
printf("xxxxxx%d",min(a++,b++));
// printf("Hello world!/n");
return 0;
}
在新的cpp中可以不用在token之间加很多的##比如
把以前需要多次链接的. [ 等直接写在上一个token上也行
在新的cpp中前一种方式会导致错误