LiteOS操作系统中,编译出的程序为什么能打印出当前时间?

举报
mculover666 发表于 2020/02/02 10:03:38 2020/02/02
【摘要】 1. 做实验引发的思考在之前学习LiteOS操作系统时,我发现一个比较有趣的现象:串口打印的日志中竟然包含着当前时间!并且,我每天做实验时,这个日期都会变化,还能保持和当前时间一致!我的好奇心被引发了,系统会不会偷偷配置了RTC,不然它怎么知道现在几点了?怀揣着问题,我决定要去探索一下。2. 系统打印出的当前时间LiteOS的日志,不仅能打印出当前日期,还能精确到时分秒:3. 揭晓谜底其实,...


1. 做实验引发的思考

在之前学习LiteOS操作系统时,我发现一个比较有趣的现象:

串口打印的日志中竟然包含着当前时间!并且,我每天做实验时,这个日期都会变化,还能保持和当前时间一致!

我的好奇心被引发了,系统会不会偷偷配置了RTC,不然它怎么知道现在几点了?

怀揣着问题,我决定要去探索一下。

2. 系统打印出的当前时间

LiteOS的日志,不仅能打印出当前日期,还能精确到时分秒:

image.png

3. 揭晓谜底

其实,这些系统之所以准确的打印出当前时间,和板子硬件没有任何关系,更不会使用的RTC,只是在代码里巧妙的利用了C语言的一个不常用知识点 —— 编译器内置宏定义

C语言编译器中内置了一些宏定义,这些内置宏定义可以巧妙地帮我们输出非常有用的调试信息,比如打印时间就用到了下面这两个宏定义:

  • __DATE__:在源文件中**当前的编译日期;

  • __TIME__:在源文件中**当前编译时间;

编写一个简单的C程序测试一下:

#include <stdio.h>int main(void){
    printf("_DATE_ is:%s\r\n", __DATE__);
    printf("_TIME_ is:%s\r\n", __TIME__);

    return 0;}

编译运行,测试结果如下:

看看LiteOS的源码实现,是不是也用__TIME____DATE__这两个宏定义实现:

static char s_link_mainversion[64];const char *linkmain_version(){
    snprintf(s_link_mainversion,64,"V%d.%d.%d AT %s ON %s",CN_LINK_VERSION_MAJOR,\
            CN_LINK_VERSION_MINOR,CN_LINK_VERSION_FEATURE,__TIME__,__DATE__);
    return s_link_mainversion;}

接收更多精彩文章及资源推送,欢迎订阅我的微信公众号:『mculover666』。

image.png



【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。