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
Logo

技术共进,成长同行——讯飞AI开发者社区

更多推荐