Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
Kernel
RT-Thread操作系统中,编译出的程序为什么能打印当前时间?
发布于 2020-02-02 09:44:22 浏览:1157
订阅该版
[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
机器人操作系统 (ROS2) 和 RT-Thread 通信
4
国产MCU移植系列教程汇总,欢迎查看!
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
NXP MCXN947 测评(2)基于GPIO 控制实现DHT11 温湿度采集
2
RT-Thread Vision Board - Bare Metal Project with VSCode/PyOCD/Cortex-Debug
3
【学习分享】libc切换 -- 从newlib切换到mlibc
4
FRDM-MCXN947开发板之i2c应用
5
esp32 s3使用cherryusb cdc
热门标签
RT-Thread Studio
串口
LWIP
Env
SPI
Bootloader
AT
ART-Pi
Hardfault
CAN总线
FinSH
USB
文件系统
DMA
RT-Thread
SCons
线程
RT-Thread Nano
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
ota在线升级
WIZnet_W5500
I2C_IIC
UART
flash
cubemx
packages_软件包
freemodbus
潘多拉开发板_Pandora
PWM
定时器
ADC
BSP
中断
编译报错
socket
keil_MDK
GD32
MicroPython
msh
Debug
ulog
SFUD
flashDB
SDIO总线
rt_mq_消息队列_msg_queue
本月问答贡献
用户名由3_15位
19
个答案
3
次被采纳
踩姑娘的小蘑菇
16
个答案
3
次被采纳
xiaorui
7
个答案
3
次被采纳
sakumisu
5
个答案
3
次被采纳
三世执戟
32
个答案
1
次被采纳
本月文章贡献
比特饼干
3
篇文章
9
次点赞
Z_Y
2
篇文章
5
次点赞
xusiwei1236
2
篇文章
3
次点赞
yinxiangxv
2
篇文章
3
次点赞
Alipay
2
篇文章
3
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部