keil里面骚气的printf
今天,在浩哥的无意之谈下。提到了keil的printf函数,当时即震惊,keilC51还能用printf。
立即google一波,还真有!!! 学习了,简直666。 分享一下心得!
注意:直接调用函数时候,初始化UART时切记要把TI置1
#include <stdio.h>
#include <reg52.h>
void ConfigUART(unsigned int baud);
void main()
{
ConfigUART(9600);
while(1)
{
printf("Hello World\n");
}
}
void ConfigUART(unsigned int baud)
{
SCON = 0X50;
TMOD &= 0x0F;
TMOD |= 0x20;
TH1 = 256 - (11059200/12/32)/baud;
TL1 = TH1;
TR1 = 1;
TI = 1;
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
原理:其底层是调用putchar函数实现的,工作方式为中断。 于是缺点就来了,此函数调用中断时会翻车。
在keil中printf默认是向串口中发送数据的,所以,如果应用该函数,必须先初始化串口,否则可能引起死机的情况,并且在printf之前应该先将TI置位,摘抄原因如下:
1.printf函数是调用putchar函数输入的,而putchar应该是先判断ti是否为1,不为1则等待为1。 如果为1则清0,然后送出一个字符。因此
你如果直接使用printf函数,你的程序就会在putchar函数中等待ti为1。这时你的程序就相当于直接死掉了。你可以通过改写putchar函数
实现自己的目的。TI相当于是初始化~不给赋初值就不干活2.Keil的串口处理比较巧妙的,我的分析如下: putchar.c里面,是先检测TI再发送。这样做的目的是把尽可能多的时间留给2次串口操作之间的程序,而不是把等待字节发送的时间白白空等待浪费
掉。所以,在系统初始化的时候,一定要令TI=1; 就可以顺畅的使用printf函数了。sbuf=” “的办法,其实就是令TI=1.
另外要特别注意,printf函数执行完毕后,最后一个字节并未发送完毕,例如在485通讯中,此时如果切换为收模式,会丢失最后一字节.3.一般串口发送都是等TI(字节发送完标志)为1就马上发送下一字节,由于不管是中断还是查 询TI标志的方法,都会检测TI,因此首次发送必须置位TI标志,使串口开始发送你的“在程序的初始化部分往串口数据寄存器SBUF里放一个字符来起用终
端显示;”方法最终作用也就是把TI置1,改成TI=1;来启动发送也是一样的(当然,不会发出那个’ ‘字符了)。4.stdio中定义,调用底层的putchar()来实现.底层发送数 据到串口时,先查TI=1是否成立,死等直到TI=1时将新数据写入SBUF,函数返回,所以要先将TI置1,启动第一次传输操作.可查看反汇编相关代码理解其工作机理!
5.自己理解:在多机通讯中,应该也要形成像 putchar()函数的机理,要有串口中断服务程序,并且是在该程序中判断TI,根据TI是不是该发送下一组数据~同样对于接收的一方..
另外
如果只进行软件调试的话,与波特率无关。可以不配置定时器T1。
只需要加一个stdio.h的头文件,以及TI = 1这个命令即可
文章来源: recclay.blog.csdn.net,作者:ReCclay,版权归原作者所有,如需转载,请联系作者。
原文链接:recclay.blog.csdn.net/article/details/75322375
- 点赞
- 收藏
- 关注作者
评论(0)