XeonGate / STM32 / ANSIC几种特殊的标准定义(_FILE_、_LINE_...

分享

   

ANSIC几种特殊的标准定义(_FILE_、_LINE_、_STDC_)及STM32F1X_Printf/Scan/Reset综合代码下载

2017-08-25  XeonGate

相关标题:__FILE__、__LINE__、__DATE__、__TIME__、__STDC__

为方便大家阅读,本文内容已经整理成PDF文件:

http://pan.baidu.com/s/1gfHygyn


Ⅰ、写在前面

对于我们大部分使用单片机进行裸机开发的朋友来说,可能很少有人在程序中许多关键的地方打印一些关键信息。

有较大系统开发,或复杂系统开发经验的朋友一般都会在程序中输出很多调试信息,如在UCOSfreeRTOSLinux等系统开发调试时打印许多关键信息。

 

1.我们在使用STM32库开发时,在stm32fxxx_conf.h文件下会发现如下这么一条语句:

#define assert_param(expr) ((expr) ? (void)0 : assert_failed((uint8_t *)__FILE__, __LINE__))

 

这条语句,对于使用寄存器,开发简单且不大程序的朋友而言,可能他觉得用处不大,它可能就觉得很占资源,且耗时。

 

其实不然,ST这么设计是有他一定的道理的,对于开发大型、复杂系统的朋友而言,这条语句其实用处很大。每次,程序运行错误之后,它会打印程序代码指定的位置,方便我们在庞大的程序中很快找到错误的位置

 

2.我们的系统会随着时间的推移,不断升级更新,也就是需要提交很多版本的可执行文件(hexbin等)。但是,产品后期使用中,我们对某些设备进行了升级,可能忽略了一些设备,也就是有些设备没有升级,如果出现故障,我们怎样才能很快找到是哪一个版本的软件出现故障呢

 

这里就需要我们在程序中添加一些关于版本的信息,我们最基础的就是Vx.x.x.x等这种信息,但对于大型系统而言,这种信息是不够的,还需要更多,比如:编译日期,时间,编译环境的版本等。

 

Ⅱ、几种特殊标准定义

上面说了这么多,就是需要让大家知道,这些特殊标准定义的用途。上面说的只是简单的举例,其实他们的用途还很广泛,掌握了基础之后相信你们都会知道它们更多比较实用的意义。言归正传,下面讲述这些基础的知识。

 

本文主要讲述下面几个标准定义:

__FILE__:正在编译文件的路径及文件名

__LINE__:正在编译文件的行号

__DATE__:编译时刻的日期字符串 Jun 17 2017

__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\Administrator\Desktop\STM32F417ZGIAR_ANSIC几种特殊的标准定义\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);

 

输出结果:

编译日期:Jun 17 2017

 

4.__TIME__编译时间

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

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

 

代码:

char BuildTime[] = __TIME__;

printf("编译时间:%s\n", BuildTime);

 

输出结果

编译时间:11:30:15

 

5.__STDC__标准C代码

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

 

#ifdef __STDC__

  printf("标准C代码文件\n");

#else

  printf("非标准C代码文件\n");

#endif

 

Ⅲ、源代码分析与下载

为了方便大家学习,本文提供的源代码比较基础和简单,也方便理论结合实际学习,仅供参考。

 

我们在之前新建好的Demo工程上添加了如下部分代码:

char BuildLine = __LINE__;

char BuildFile[] = __FILE__;

char BuildDate[] = __DATE__;

char BuildTime[] = __TIME__;

 

printf("编译文件路径:%s\n", BuildFile);

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

 

printf("编译日期:%s\n", BuildDate);

printf("编译时间:%s\n", BuildTime);

 

#ifdef __STDC__

  printf("标准C代码文件\n");

#else

  printf("非标准C代码文件\n");

#endif

 

Keil版本输出结果

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

编译代码所在行:44

编译日期:Jun 17 2017

编译时间:11:30:15

标准C代码文件

 

IAR版本输出结果:

编译文件路径:C:\Users\Administrator\Desktop\STM32F417ZGIAR_ANSIC几种特殊的标准定义\App\main.c

编译代码所在行:44

编译日期:Jun 17 2017

编译时间:11:45:00

标准C代码文件

 

源代码工程(STM32F417ZG_ANSIC几种特殊的标准定义

STM32F1X_Printf/Scan/Reset综合代码下载:

下载地址:

http://pan.baidu.com/s/1hskScba

 

提示:如果网盘链接失效,可以微信公众号“底部菜单”查看更新链接。

Ⅳ、最后

微信搜索EmbeddDeveloper” 或者扫描下面二维码、关注,查看更多精彩内容!

 


    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多
    喜欢该文的人也喜欢 更多

    ×
    ×

    ¥.00

    微信或支付宝扫码支付:

    开通即同意《个图VIP服务协议》

    全部>>