stm32库的断言(assert),官方提供了包含“__FILE__,__LINE__”的代码。
标准外设库位于stm32fxxx.conf.h文件:
#define USE_FULL_ASSERT 1U
#define assert_param(expr) ((expr) ? (void)0U : assert_failed((uint8_t *)__FILE__, __LINE__))
void assert_failed(uint8_t *file, uint32_t line)
{
/* User can add his own implementation to report the file name and line number,*/
printf("Wrong parameters value: file %s on line %d\r\n", file, line);
}
C几种特殊标准定义
__FILE__ :正在编译文件的文件名
__LINE__ :正在编译文件的行号
__DATE__:编译时刻的日期字符串 如“Sep 22 2020”
__TIME__:编译时刻的时间字符串 如”10:00:00“
__STDC__:判断该文件是不是标准C程序
1.__FILE__编译文件名称
File中文意思即文件,这里的意思主要是指:正在编译文件对应正在编译文件的路径和文件的名称。
源代码:
- char BuildFile[] = __FILE__;
- printf("编译文件路径:%s\n",BuildFILE);
2.__LINE__编译文件行号
上面说的是编译的文件名,是一个字符串,而这里说的是行号,是一个整型变量,这是这两者的区别,比如在工程中添加源代码:
char BuildLine = __LINE__;
printf('编译代码所在行:%d\n', BuildLine);
可以看不是数组的字符串,打印信息:
编译代码所在行:48
一般情况下,__FILE__是和__LINE__结合一起使用,用于打印我们代码信息,方便快速定位代码位置。
3.__DATE__编译日期
__DATE__日期,需要注意的是:这个日期是你在编译时Windows系统的日期,如果对应那部分代码之前编译好了,后面没有编译,这个日期还是之前的日期,而不是后面编译的日期。因此,如果这里用于定版本,就需要在定版本时对工程进行全部重新编译,它才会更新至你最后编译的日期。
代码:
char BuildDate[] = __DATE__;
printf('编译日期:%s\n', BuildDate);
输出结果:
编译日期:Sep 11 2021
4.__TIME__编译时间
这个和__DATE__一样的原理,编译时的时间,也是一个字符串。
再次提醒:用于定版本:需要重新编译,这样才是最后一次编译时间。
代码:
char BuildTime[] = __TIME__;
printf('编译时间:%s\n', BuildTime);
输出结果 编译时间:10:20:00
5.__STDC__标准C代码
单片机及嵌入式编程中运用的比较少,当要求程序严格遵循ANSIC标准时该标识符被赋值为1,主要是判断我们的程序文件是不是标准C程序。
#ifdef __STDC__
printf('标准C代码文件\n');
#else
printf('非标准C代码文件\n');
#endif
6.打印调试信息
#define DEBUG_MODE 0
#if DEBUG_MODE
#define DBG_PRINTF(fmt,args...) \
do{\
printf("<<File:%s Line %d Function:%s>>",__FILE__,__LINE__,__FUNCTION__);\
printf(fmt,##args);\
}while(0)
#else
#define DBG_PRINTF(fmt, arg...)
#endif