Keil C51重定向printf到串口
概述
進(jìn)行C/C++開(kāi)發(fā)的時(shí)候我們都會(huì)需要打印調(diào)試信息,打印調(diào)試信息時(shí)我們習(xí)慣使用printf函數(shù),但是在Keil C51環(huán)境下,由于我們的程序是下載到單片機(jī)里,使用printf函數(shù)時(shí)不能直接打印到串口上,這個(gè)時(shí)候就需要我們對(duì)printf函數(shù)輸出重定向。
重定向
重定向printf很簡(jiǎn)單,我們知道,printf函數(shù)是調(diào)用putchar實(shí)現(xiàn)字符數(shù)據(jù)傳送的。我們只要重寫(xiě)putchar函數(shù),就可以對(duì)printf進(jìn)輸出重定向。
代碼清單
下面是自己在Keil 5環(huán)境下,使用單片機(jī)STC12測(cè)試printf重定向功能的代碼清單
#include
#include
//UART1 初始化
void Uart1Init(void) //115200bps@11.0592MHz
{
PCON &= 0x7F; //波特率不倍速
SCON = 0x50; //8位數(shù)據(jù),可變波特率
AUXR |= 0x04; //1T模式
BRT = 0xFD; //設(shè)置獨(dú)立波特率發(fā)生器重裝值
AUXR |=0X01; //串口1選擇獨(dú)立發(fā)生器為波特率發(fā)生器
AUXR |=0X10; //啟動(dòng)獨(dú)立波特率發(fā)生器
ES = 1; //使能串口1中斷
}
//UART1 發(fā)送串口數(shù)據(jù)
void UART1_SendData(char dat)
{
ES=0; //關(guān)串口中斷
SBUF=dat;
while(TI!=1); //等待發(fā)送成功
TI=0; //清除發(fā)送中斷標(biāo)志
ES=1; //開(kāi)串口中斷
}
//UART1 發(fā)送字符串
void UART1_SendString(char *s)
{
while(*s)//檢測(cè)字符串結(jié)束符
{
UART1_SendData(*s++);//發(fā)送當(dāng)前字符
}
}
//重寫(xiě)putchar函數(shù)
char putchar(char c)
{
UART1_SendData(c);
return c;
}
void main(void)
{
Uart1Init();
UART1_SendString("Hello World!\r\n");
printf("printf Test!\r\n");
printf("Complie Time:%s\r\n", __TIME__);
while(1)
{
}
}12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
打開(kāi)串口把波特率調(diào)成115200bps,可以看到串口打印如下信息:
Hello World!
printf Test!
Complie Time:11:12:36
編輯:admin 最后修改時(shí)間:2018-05-18