新聞中心

keil中printf

作者: 時間:2016-11-27 來源:網(wǎng)絡(luò) 收藏
keilprintf 默認是向串口中發(fā)送數(shù)據(jù)的,所以,如果應(yīng)用該函數(shù),必須先初始化串口,否則可能引起死機的情況,并且在printf之前應(yīng)該先將TI置位,摘抄原因如下:

1.printf函數(shù)是調(diào)用putchar函數(shù)輸入的,而putchar應(yīng)該是先判斷ti是否為1,不為1則等待為1。如果為1則清0,然后送出一個字符。因此 你如果直接使用printf函數(shù),你的程序就會在putchar函數(shù)中等待ti為1。這時你的程序就相當(dāng)于直接死掉了。你可以通過改寫putchar函數(shù) 實現(xiàn)自己的目的。TI相當(dāng)于是初始化~不給賦初值就不干活

本文引用地址:http://butianyuan.cn/article/201611/322128.htm

2.Keil的串口處理比較巧妙的,我的分析如下:
putchar.c里面,是先檢測TI再發(fā)送。這樣做的目的是把盡可能多的時間留給2次串口操作之間的程序,而不是把等待字節(jié)發(fā)送的時間白白空等待浪費 掉。所以,在系統(tǒng)初始化的時候,一定要令TI=1; 就可以順暢的使用printf函數(shù)了。摟主sbuf=" "的辦法,其實就是令TI=1.另外要特別注意,printf函數(shù)執(zhí)行完畢后,最后一個字節(jié)并未發(fā)送完畢,例如在485通訊中,此時如果切換為收模式,會丟失最后一字節(jié).

3.一般串口發(fā)送都是等TI(字節(jié)發(fā)送完標(biāo)志)為1就馬上發(fā)送下一字節(jié),由于不管是中斷還是查 詢TI標(biāo)志的方法,都會檢測TI,因此首次發(fā)送必須置位TI標(biāo)志,使串口開始發(fā)送你的“在程序的初始化部分往串口數(shù)據(jù)寄存器SBUF里放一個字符來起用終 端顯示;”方法最終作用也就是把TI置1,改成TI=1;來啟動發(fā)送也是一樣的(當(dāng)然,不會發(fā)出那個 字符了)。

4.中定義,調(diào)用底層的putchar()來實現(xiàn).底層發(fā)送數(shù) 據(jù)到串口時,先查TI=1是否成立,死等直到TI=1時將新數(shù)據(jù)寫入SBUF,函數(shù)返回,所以要先將TI置1,啟動第一次傳輸操作.可查看反匯編相關(guān)代碼 理解其工作機理!

5.自己理解:在多機通訊中,應(yīng)該也要形成像 putchar()函數(shù)的機理,要有串口中斷服務(wù)程序,并且是在該程序中判斷TI,根據(jù)TI是不是該發(fā)送下一組數(shù)據(jù)~同樣對于接收的一方..



關(guān)鍵詞: keilprint

評論


技術(shù)專區(qū)

關(guān)閉