良许Linux教程网 干货合集 __FILE__、__LINE__等几种C标准用法

__FILE__、__LINE__等几种C标准用法

C语言有许多特殊用法,如果这些用法被适当地运用,会使你的代码更健壮且更容易维护。

例如,在使用STM32库的断言(assert)时,你会发现官方提供了包含“__FILE__、__LINE__”的代码。

标准外设库位于stm32fxxx_conf.h文件中,它包含以下代码:

#define assert_param(expr) ((expr) ? (void)0 : assert_failed((uint8_t *)FILE, LINE))

这段代码中包含了宏定义assert_param(expr),用于判断某个表达式是否成立,如果表达式不成立,就会调用assert_failed((uint8_t*)FILE, LINE)函数进行错误报告。关于函数assert_failed()的实现方式需要自行设置,以适应具体的应用程序需要。

除了这个例子外,还有一些其他的特殊用法,例如内联函数(inline functions)、宏定义(macros)和模板(templates)。这些用法可以简化代码、提高代码效率、降低内存使用量以及提高代码可读性和可维护性。

在使用这些特殊用法时需要注意,它们只应当用于特定的应用场景以及结构简单的代码中。如果使用不当,很可能会导致代码的错误或增加代码的复杂度。因此,在具体的应用中需要仔细考虑特殊用法的使用和实现方式。

image-20231207191802894
image-20231207191802894

在代码中会看见如下代码:

image-20231207191806021
image-20231207191806021

如果添加了这段断言代码,对于开发大型、复杂的系统,这条语句其实用处很大。每次程序运行错误之后,它会打印程序代码指定的位置,方便我们在庞大的程序中很快找到错误的位置。

我们的系统会随着时间的推移,不断升级更新,也就是需要提交很多版本的可执行文件(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:

编译文件路径:App\main.c

IAR:

编译文件路径:C:\Users\strongerHuang\Desktop\工程主目录\App\main.c

2.__LINE__编译文件行号

上面说的是编译的文件名,是一个字符串,而这里说的是行号,是一个整型变量,这是这两者的区别,

比如在工程中添加源代码:

char BuildLine = __LINE__;
printf("编译代码所在行:%d\n", BuildLine);

可以看不是数组的字符串,打印信息:

编译代码所在行:44

一般情况下,__FILE__是和__LINE__结合一起使用,用于打印我们代码信息,方便快速定位代码位置。

3.__DATE__编译日期

__DATE__日期,需要注意的是:这个日期是你在编译时Windows系统的日期,如果对应那部分代码之前编译好了,后面没有编译,这个日期还是之前的日期,而不是后面编译的日期。因此,如果这里用于定版本,就需要在定版本时对工程进行全部重新编译,它才会更新至你最后编译的日期。

代码:

char BuildDate[] = __DATE__;
printf("编译日期:%s\n", BuildDate);

输出结果:

编译日期:Sep 22 2017

4.__TIME__编译时间

这个和__DATE__一样的原理,编译时的时间,也是一个字符串。

再次提醒:用于定版本:需要重新编译,这样才是最后一次编译时间。

代码:

char BuildTime[] = __TIME__;
printf("编译时间:%s\n", BuildTime);

输出结果

编译时间:10:00:00

5.__STDC__标准C代码

这个标准在我们单片机及嵌入式编程中运用的比较少,当要求程序严格遵循ANSIC标准时该标识符被赋值为1,主要是判断我们的程序文件是不是标准C程序。

代码:

#ifdef __STDC__
  printf("标准C代码文件\n");
#else
  printf("非标准C代码文件\n");
#endif

以上就是良许教程网为各位朋友分享的Linu系统相关内容。想要了解更多Linux相关知识记得关注公众号“良许Linux”,或扫描下方二维码进行关注,更多干货等着你 !

137e00002230ad9f26e78-265x300
本文由 良许Linux教程网 发布,可自由转载、引用,但需署名作者且注明文章出处。如转载至微信公众号,请在文末添加作者公众号二维码。
良许

作者: 良许

良许,世界500强企业Linux开发工程师,公众号【良许Linux】的作者,全网拥有超30W粉丝。个人标签:创业者,CSDN学院讲师,副业达人,流量玩家,摄影爱好者。
上一篇
下一篇

发表评论

联系我们

联系我们

公众号:良许Linux

在线咨询: QQ交谈

邮箱: yychuyu@163.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部