在开发软件KEIL MDK和IAR开发工程里面打印行号、文件名、函数名、时间

最近应用固件没有时间记录,分别请那个是最新的(在没有版本区别的情况下),有个办法记录编译时间即可,记录笔记以便查看
在软件工程里面直接用宏
__FILE __ 当前程序文件名的字符串
__FUNCTION __ 当前函数的名字字符串
__LINE __ 当前行数整型
__TATE __ 当前日期
__TIME __ 当前时间

测试一下例题,如下

void AppWritedToFlash(void)
{
  printf("\n*********************************************************\n");  
  printf("Time:%s%s\nfuncName:%s\nLine:%d\n",__DATE__,__TIME__,__FUNCTION__,__LINE__);
  printf("OTA executed now \r\n");
  printf("pragraming....\r\n");
  printf("\n*********************************************************\n"); 
  }

串口助手打印信息如下

*********************************************************
Time:Dec 6 2023 17:34:57
funcName:AppWritedToFlash
Line:170
OTA executed now 
pragraming....

*********************************************************
  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Keil5中,可以使用标准库函数来调用时间函数。具体步骤如下: 1. 首先,需要包含头文件`time.h`,该头文件中包含了与时间相关的函数和结构体的声明。 2. 在程序中,可以使用`time()`函数来获取当前的系统时间。该函数返回一个`time_t`类型的值,表示从1970年1月1日00:00:00到当前时间的秒数。 3. 如果需要将时间转换为可读的格式,可以使用`localtime()`函数将`time_t`类型的值转换为`struct tm`类型的结构体。该结构体中包含了年、月、日、时、分、秒等信息。 4. 可以通过访问`struct tm`结构体中的成员来获取具体的时间信息,例如`tm_year`表示年份,`tm_mon`表示月份(范围为0-11),`tm_mday`表示日期,`tm_hour`表示小时,`tm_min`表示分钟,`tm_sec`表示秒钟。 下面是一个示例代码: ```c #include <time.h> #include <stdio.h> int main() { time_t currentTime; struct tm *localTime; // 获取当前时间 currentTime = time(NULL); // 转换为本地时间 localTime = localtime(&currentTime); // 输出时间信息 printf("当前时间:%d年%d月%d日 %02d:%02d:%02d\n", localTime->tm_year + 1900, localTime->tm_mon + 1, localTime->tm_mday, localTime->tm_hour, localTime->tm_min, localTime->tm_sec); return 0; } ``` 在上述示例代码中,首先使用`time()`函数获取当前时间,然后使用`localtime()`函数时间转换为本地时间,最后通过访问`struct tm`结构体中的成员来输出具体的时间信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值