C语言有很多特殊的用法,如果这些特殊用法使用得当,会是你的代码变得更加有健壮,更加容易维护。
比如我们在使用STM32库的断言(assert),你会发现官方提供了包含“__FILE__、__LINE__”的代码。
标准外设库位于stm32fxxx_conf.h文件:
#define assert_param(expr) ((expr) ? (void)0 : assert_failed((uint8_t *)__FILE__, __LINE__))
HAL使能Assert:
在代码中会看见如下代码:
如果添加了这段断言代码,对于开发大型、复杂的系统,这条语句其实用处很大。每次程序运行错误之后,它会打印程序代码指定的位置,方便我们在庞大的程序中很快找到错误的位置。
我们的系统会随着时间的推移,不断升级更新,也就是需要提交很多版本的可执行文件(hex、bin等)。但是,产品后期使用中,我们对某些设备进行了升级,可能忽略了一些设备(忘记升级),如果出现故障,我们怎样才能很快找到是哪一个版本的软件出现故障呢?
我们的系统会随着时间的推移,不断升级更新,也就是需要提交很多版本的可执行文件(hex、bin等)。但是,产品后期使用中,我们对某些设备进行了升级,可能忽略了一些设备(忘记升级),如果出现故障,我们怎样才能很快找到是哪一个版本的软件出现故障呢?
C几种特殊标准定义
__FILE__ :正在编译文件的文件名__LINE__ :正在编译文件的行号__DATE__:编译时刻的日期字符串 如“Sep 22 2020”__TIME__:编译时刻的时间字符串 如”1000“__STDC__:判断该文件是不是标准C程序
1.__FILE__编译文件名称
File中文意思即文件,这里的意思主要是指:正在编译文件对应正在编译文件的路径和文件的名称。
Keil版本对应的路径是相对于工程文件而言的路径,IAR版本路径是相对Windows路径。
源代码:
char BuildFile[] = __FILE__;printf("编译文件路径:%s ", BuildFile);
Keil:
编译文件路径:Appmain.c
IAR:
编译文件路径:C:UsersstrongerHuangDesktop工程主目录Appmain.c
2.__LINE__编译文件行号上面说的是编译的文件名,是一个字符串,而这里说的是行号,是一个整型变量,这是这两者的区别, 比如在工程中添加源代码:
char BuildLine = __LINE__;printf("编译代码所在行:%d ", BuildLine); 可以看不是数组的字符串,打印信息: 编译代码所在行:44 一般情况下,__FILE__是和__LINE__结合一起使用,用于打印我们代码信息,方便快速定位代码位置。 3.__DATE__编译日期__DATE__日期,需要注意的是:这个日期是你在编译时Windows系统的日期,如果对应那部分代码之前编译好了,后面没有编译,这个日期还是之前的日期,而不是后面编译的日期。因此,如果这里用于定版本,就需要在定版本时对工程进行全部重新编译,它才会更新至你最后编译的日期。 代码:
char BuildDate[] = __DATE__;printf("编译日期:%s ", BuildDate); 输出结果: 编译日期:Sep 22 2017 4.__TIME__编译时间这个和__DATE__一样的原理,编译时的时间,也是一个字符串。 再次提醒:用于定版本:需要重新编译,这样才是最后一次编译时间。 代码:
char BuildTime[] = __TIME__;printf("编译时间:%s ", BuildTime); 输出结果 编译时间:1000 5.__STDC__标准C代码这个标准在我们单片机及嵌入式编程中运用的比较少,当要求程序严格遵循ANSIC标准时该标识符被赋值为1,主要是判断我们的程序文件是不是标准C程序。 代码:
#ifdef __STDC__ printf("标准C代码文件 ");#else printf("非标准C代码文件 ");#endif 推荐阅读:
责任编辑:xj
原文标题:__FILE__、__LINE__等几种C标准用法
文章出处:【微信公众号:strongerHuang】欢迎添加关注!文章转载请注明出处。
全部0条评论
快来发表一下你的评论吧 !