1. 预定义标识符
预定义标识符打印文件名,行号,函数名称,日期及时间,这在调试和日志输出时比较常用。
__FILE__ //当前源文件名
__LINE__ //当前的行号
__FUNCTION__ //当前函数名
__DATE__ //编译日期
__TIME__ //编译时间
//举例
printf("file:%s, line:%d, function:%s, date:%s, time:%s",\
__FILE__, __LINE__, __FUNCTION__, __DATE__, __TIME__);
2. 宏定义中#和##的应用
- #: 将后面的参数转换为字符串,返回值是字符串
- ##: 连接数字 ;求
指数
。返回值是数字
#define ALT_TO_STR(num) #num
#define JOINT_STR(a,b) a##b
#define POWER(a,b) a##e##b
//举例
printf("ALT_TO_STR %s\n",ALT_TO_STR(ssss));
printf("ALT_TO_STR %s\n",ALT_TO_STR(123));
printf("ALT_TO_STR %s\n",ALT_TO_STR(123.1));
printf("JOINT %d\n", JOINT(1, 2)); //%d
printf("POWER %f\n", POWER(2, 3)); //%f
//输出
ALT_TO_STR ssss
ALT_TO_STR 123
ALT_TO_STR 123.1
JOINT 12
POWER 2000.000000