这是编译器内置宏,这些宏定义不仅可以帮助我们完成跨平台的源码编写,灵活使用也可以巧妙地帮我们输出非常有用的调试信息。例如:
printf("FILE: %d, LINE: %d, %s/n", "__FILE__, __LINE__, "这里写上相关信息");
ANSI C标准中几个标准预定义宏:
__LINE__:在源代码中插入当前源代码行号;
__FILE__:在源文件中插入当前源文件名;
__DATE__:在源文件中插入当前的编译日期
__TIME__:在源文件中插入当前编译时间;
__STDC__:当要求程序严格遵循ANSI C标准时该标识被赋值为1;
__cplusplus:当编写C++程序时该标识符被定义。
注意,是双下划线,而不是单下划线
__FILE__ 包含当前程序文件名的字符串
__LINE__ 表示当前行号的整数
__DATE__ 包含当前日期的字符串
__STDC__ 如果编译器遵循ANSI C标准,它就是个非零值
__TIME__ 包含当前时间的字符串
例如:
输出当前程序文件名的程序:
//---------------------------------------------------------------------------
#include
int main(void)
{
printf("%s",__FILE__);
return 0;
}
//---------------------------------------------------------------------------
如果添加了这段断言代码,对于开发大型、复杂的系统,这条语句其实用处很大。每次程序运行错误之后,它会打印程序代码指定的位置,方便我们在庞大的程序中很快找到错误的位置。
我们的系统会随着时间的推移,不断升级更新,也就是需要提交很多版本的可执行文件(hex、bin等)。但是,产品后期使用中,我们对某些设备进行了升级,可能忽略了一些设备(忘记升级),如果出现故障,我们怎样才能很快找到是哪一个版本的软件出现故障呢?
我们的系统会随着时间的推移,不断升级更新,也就是需要提交很多版本的可执行文件(hex、bin等)。但是,产品后期使用中,我们对某些设备进行了升级,可能忽略了一些设备(忘记升级),如果出现故障,我们怎样才能很快找到是哪一个版本的软件出现故障呢?
C几种特殊标准定义
__FILE__ :正在编译文件的文件名
__LINE__ :正在编译文件的行号
__DATE__:编译时刻的日期字符串 如“Sep 22 2020”
__TIME__:编译时刻的时间字符串 如”10:00:00“
__STDC__:判断该文件是不是标准C程序
1.__FILE__编译文件名称
File中文意思即文件,这里的意思主要是指:正在编译文件对应正在编译文件的路径和文件的名称。
Keil版本对应的路径是相对于工程文件而言的路径,IAR版本路径是相对Windows路径。
源代码:
char BuildFile[] = __FILE__;
printf("编译文件路径:%s\n", BuildFile);
Keil:
编译文件路
IAR:
编译文件路径
2.__LINE__编译文件行号
上面说的是编译的文件名,是一个字符串,而这里说的是行号,是一个整型变量,这是这两者的区别,
比如在工程中添加源代码:
char BuildLine = __LINE__;
printf("编译代码所在行:%d\n", BuildLine);
可以看不是数组的字符串,打印信息:
编译代码所在行:44
一般情况下,__FILE__是和__LINE__结合一起使用,用于打印我们代码信息,方便快速定位代码位置。
3.__DATE__编译日期
__DATE__日期,需要注意的是:这个日期是你在编译时Windows系统的日期,如果对应那部分代码之前编译好了,后面没有编译,这个日期还是之前的日期,而不是后面编译的日期。因此,如果这里用于定版本,就需要在定版本时对工程进行全部重新编译,它才会更新至你最后编译的日期
printf("\n [%s]: %d ", __FUNCTION__, __LINE__);
打印出 函数名称 和 行号
很简单 是c的宏定义 不需要头文件
goodluck
源文件名用%d打印是不是有点问题呢?