在網上找資料時找到一篇介紹在keil中使用printf()函數的文章,copy到這里,作為備忘。
在keil中printf默認是向串口中發送數據的,所以,如果應用該函數,必須先初始化串口,否則可能引起死機的情況,并且在printf之前應該先將TI置位,摘抄原因如下:
1.printf 函數是調用putchar函數輸入的,而putchar應該是先判斷ti是否為1,不為1則等待為1。如果為1則清0,然后送出一 個字符。因此你如果直接使用printf函數,你的程序就會在putchar函數中等待ti為1。這時你的程序就相當于直接死掉了。你可以通過改寫 putchar函數實現自己的目的的。
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.h>中定義,調用底層的putchar()來實現.底層發送數據到串口時,先查TI=1是否成立,死等直到TI=1時將新數據寫入SBUF,函數返回,所以要先將TI置1,啟動第一次傳輸操作.可查看反匯編相關代碼理解其工作機理!
下面舉一個簡單的例子:
//===========================
#include <reg51.h>
#include <stdio.h>
//-------------------------------
int main()
{
Uart_init(); //初始化串口,這里就不寫具體代碼了。
TI = 1; //keil 調用stdio.h中printf函數前要置位。
while(1)
{
printf("Hello world!\n");
delay_ms(800); //延時程序,這里也不寫具體代碼了。
}
return 0;
}
下面舉一個簡單的例子:
//===========================
#include <reg51.h>
#include <stdio.h>
//-------------------------------
int main()
{
Uart_init(); //初始化串口,這里就不寫具體代碼了。
TI = 1; //keil 調用stdio.h中printf函數前要置位。
while(1)
{
printf("Hello world!\n");
delay_ms(800); //延時程序,這里也不寫具體代碼了。
}
return 0;
}