Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Kernel
RT-Thread操作系统中,编译出的程序为什么能打印当前时间?
发布于 2020-02-02 09:44:22 浏览:1248
订阅该版
[tocm] * 本帖最后由 Mculover666 于 2020-2-2 09:50 编辑 * # 1. 做实验引发的思考 在之前学习RT-Thread操作系统时,我发现一个比较有趣的现象: **串口打印的日志中竟然包含着当前时间!并且,我每天做实验时,这个日期都会变化,还能保持和当前时间一致!** 我的好奇心被引发了,系统会不会偷偷配置了RTC,不然它怎么知道现在几点了? 怀揣着问题,我决定要去探索一下。 # 2. 系统打印出的当前时间 这是RT-Thread刚上电时控制台默认打印的内容,可以看到日期在今天: ![](![FastAdmin](https://img-blog.csdnimg.cn/2020020208452517.png)) # 3. 揭晓谜底 其实,这些系统之所以准确的打印出当前时间,和板子硬件没有任何关系,更不会使用的RTC,只是在代码里巧妙的利用了C语言的一个不常用知识点 —— **编译器内置宏定义**。 C语言编译器中内置了一些宏定义,这些内置宏定义可以巧妙地帮我们输出非常有用的调试信息,比如打印时间就用到了下面这两个宏定义: - `__DATE__`:在源文件中插入当前的编译日期; - `__TIME__`:在源文件中插入当前编译时间; 编写一个简单的C程序测试一下: ```c #include
int main(void) { printf("_DATE_ is:%s
", __DATE__); printf("_TIME_ is:%s
", __TIME__); return 0; } ``` 编译运行,测试结果如下: ![](![FastAdmin](https://img-blog.csdnimg.cn/20200202091734250.png)#pic_center) RT-Thread的源码实现如下,是不是用`__DATE__`这个宏定义实现: ```c void rt_show_version(void) { rt_kprintf("
\\ | /
"); rt_kprintf("- RT - Thread Operating System
"); rt_kprintf(" / | \\ %d.%d.%d build %s
", RT_VERSION, RT_SUBVERSION, RT_REVISION, __DATE__); rt_kprintf(" 2006 - 2019 Copyright by rt-thread team
"); } ``` 接收更多精彩文章及资源推送,欢迎订阅我的微信公众号:『mculover666』。 ![](![FastAdmin](https://img-blog.csdnimg.cn/20200202092055136.png))
查看更多
1
个回答
默认排序
按发布时间排序
whj467467222
认证专家
2020-02-02
开源,分享,交流,共同进步
这个只能显示编译的时间。公众号已关注。
撰写答案
登录
注册新账号
关注者
0
被浏览
1.2k
关于作者
Mculover666
这家伙很懒,什么也没写!
提问
10
回答
14
被采纳
0
关注TA
发私信
相关问题
1
请教cpu使用率分析
2
选择FreeRTOS, 还是RT-Thread。
3
thread heap stack overflow ?
4
rtt消息队列delay问题
5
释放被删除线程的内存地方在哪里啊
6
请教:各线程结束后,释放其中的内存的连续性问题
7
STM32F103中断关于信号量、邮箱问题
8
RTT中的线程栈大小如何控制
9
关于线程由执行态变为挂起态的代码实现,,,
10
rt_malloc(rt_size_t size)内存分配函数最小分配尺寸问题
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
使用百度AI助手辅助编写一个rt-thread下的ONVIF设备发现功能的功能代码
2
RT-Thread 发布 EtherKit开源以太网硬件!
3
rt-thread使用cherryusb实现虚拟串口
4
《C++20 图形界面程序:速度与渲染效率的双重优化秘籍》
5
《原子操作:程序世界里的“最小魔法单位”解析》
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
WIZnet_W5500
UART
ota在线升级
PWM
cubemx
freemodbus
flash
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
GD32
flashDB
socket
中断
Debug
编译报错
msh
SFUD
keil_MDK
rt_mq_消息队列_msg_queue
ulog
C++_cpp
at_device
本月问答贡献
踩姑娘的小蘑菇
7
个答案
3
次被采纳
a1012112796
13
个答案
2
次被采纳
张世争
9
个答案
2
次被采纳
rv666
5
个答案
2
次被采纳
用户名由3_15位
11
个答案
1
次被采纳
本月文章贡献
程序员阿伟
8
篇文章
2
次点赞
hhart
3
篇文章
4
次点赞
大龄码农
1
篇文章
5
次点赞
ThinkCode
1
篇文章
1
次点赞
Betrayer
1
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部