Ⅰ、写在前面
对于我们大部分使用单片机进行裸机开发的朋友来说,可能很少有人在程序中许多关键的地方打印一些关键信息。
有较大系统开发,或复杂系统开发经验的朋友一般都会在程序中输出很多调试信息,如在UCOS、freeRTOS、Linux等系统开发调试时打印许多关键信息。
1.我们在使用STM32库开发时,在stm32fxxx_conf.h文件下会发现如下这么一条语句:
#define assert_param(expr) ((expr) ? (void)0 : assert_failed((uint8_t *)__FILE__, __LINE__))
这条语句,对于使用寄存器,开发简单且不大程序的朋友而言,可能他觉得用处不大,它可能就觉得很占资源,且耗时。
其实不然,ST这么设计是有他一定的道理的,对于开发大型、复杂系统的朋友而言,这条语句其实用处很大。每次,程序运行错误之后,它会打印程序代码指定的位置,方便我们在庞大的程序中很快找到错误的位置。
2.我们的系统会随着时间的推移,不断升级更新,也就是需要提交很多版本的可执行文件(hex、bin等)。但是,产品后期使用中,我们对某些设备进行了升级,可能忽略了一些设备,也就是有些设备没有升级,如果出现故障,我们怎样才能很快找到是哪一个版本的软件出现故障呢?
这里就需要我们在程序中添加一些关于版本的信息,我们最基础的就是Vx.x.x.x等这种信息,但对于大型系统而言,这种信息是不够的,还需要更多,比如:编译日期,时间,编译环境的版本等。
Ⅱ、几种特殊标准定义
上面说了这么多,就是需要让大家知道,这些特殊标准定义的用途。上面说的只是简单的举例,其实他们的用途还很广泛,掌握了基础之后相信你们都会知道它们更多比较实用的意义。言归正传,下面讲述这些基础的知识。
本文主要讲述下面几个标准定义:
__FILE__:正在编译文件的路径及文件名
__LINE__:正在编译文件的行号
__DATE__:编译时刻的日期字符串 如“Jun 17 2017”
__TIME__:编译时刻的时间字符串 如”10:00:00“
__STDC__:判断该文件是不是标准C程序
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
全部0条评论
快来发表一下你的评论吧 !