宏定义:
1.常量 单参数
2.变量多参数
多参数要注意加括号。
多参数换行需要加 \ 。
3.注意和函数的区别。
4.宏定义单纯的替换,不会检查类型,无返回值。
#include <stdio.h>
#include "time.h"
char *currentTime ()
{
time_t rawtime;
struct tm * timeinfo;
time ( &rawtime );
timeinfo = localtime ( &rawtime );
//printf ( "\007The current date/time is: %s", asctime (timeinfo) );
return asctime(timeinfo);
}
#define MAXNUM(A,B) A>B?A:B
//多行宏定义
#define LOOP(FROM,TO,CONTENT)\
for(int index=FROM;index<TO;index++){\
CONTENT;\
}
void snsslmmSayHi(){
printf("HI\n");
}
void snsslmmSayHello(){
printf("HELLO\n");
}
//参数连接(换名)
#define SS_NEWNAME(EXNAME) snsslmm##EXNAME()
//可变参数:级别示例
#define LOG(LEVEL,FORMAT,...) printf(LEVEL);printf(FORMAT,__VA_ARGS__)
#define LOG_E(FORMAT,...) LOG("ERROR:",FORMAT,__VA_ARGS__)
#define LOG_W(FORMAT,...) LOG("WARNING:",FORMAT,__VA_ARGS__)
#define LOG_I(FORMAT,...) LOG("INFO:",FORMAT,__VA_ARGS__)
#define LOG_D(FORMAT,...) LOG("DEBUG:",FORMAT,__VA_ARGS__)
int main(void) {
printf("Max num is %f\n",MAXNUM(10.1,5.5));
LOOP(0,3,printf("Current num is %d\n",index));
SS_NEWNAME(SayHi);
SS_NEWNAME(SayHello);
LOG_D("[%s]\n",currentTime());
return 0;
}