ANSI C标准中有几个标准预定义宏:__FILE__ __DATE__ __TIME___ __LINE__ 等
__LINE__:在源代码中插入当前源代码行号;
__FILE__:在源文件中插入当前源文件名;
__DATE__:在源文件中插入当前的编译日期
__TIME__:在源文件中插入当前编译时间;
__STDC__:当要求程序严格遵循ANSI C标准时该标识被赋值为1;
__cplusplus:当编写C++程序时该标识符被定义。
这几个宏比较有用~~~~~~~~
在调试程序时或编译时,__LINE__比较有用,可以用来打印逻辑错误的行号~~~~~~~,例子:
switch(x)
{
case 1:
....;
break;
case 2:
.....;
break;
default:
printf("logic erro line number%d!/n",__LINE__);
break;
}
又如利用__DATE__和__TIME__可以插入编译时间。
代码:
void print_version_info(void)
{
printf("Date Compiled:%s/n",__DATE__);
printf("TimeCompiled:%s/n",__TIME__);
}
输出格式为:mm dd yy 和 hh:mm:ss
作用:对于__FILE__,__LINE__,__func__这样的宏,在调试程序时是很有用的,因为你可以很容易的知道程序运行到了哪个文件的那一 行,是哪个函数。
下面一个例子是打印上面这些预定义的宏的。
__DATE__,__FILE__,__LINE__,__TIME__,__FUNCTION__ C标准中指定了一些预定义的宏,对于编程经常会用到。下面这个表中就是一些常常用到的预定义宏。
__DATE_ %s_
进行预处理的日期(“Mmm dd yyyy”形式的字符串文字)
__FILE__ %s
代表当前源代码文件名的字符串文字
__LINE__ %d
代表当前源代码中的行号的整数常量
__TIME__ %s
源文件编译时间,格式微“hh:mm:ss”
__FUNCTION__(__func__) %s
当前所在函数名
__PRETTY_FUNCTION__
%s
当前所在函数名,包括返回类型和参数类型。
例如:printf("__PRETTY_FUNCTION__:%s/n", __PRETTY_FUNCTION__);
输出:__PRETTY_FUNCTION__:int main(int, char**)
#include <stdio.h>
#include <stdlib.h>
void why_me();
int main()
{
printf( "The file is %s./n", __FILE__ );
printf( "The date is %s./n", __DATE__ );
printf( "The time is %s./n", __TIME__ );
printf( "This is line %d./n", __LINE__ );
printf( "This function is %s./n", __FUNCTION__ );
why_me();
return 0;
}
void why_me()
{
printf( "This function is %s/n", __func__ );
printf( "The file is %s./n", __FILE__ );
printf( "This is line %d./n", __LINE__ );
}