經(jīng)驗之談:如何學(xué)好單片機
摘要:單片機越來(lái)越多的受到電子產(chǎn)品研發(fā)人員和我國高等技術(shù)類(lèi)學(xué)校的應用與重視。本文在多年實(shí)際經(jīng)驗的基礎上,從單片機結構、邏輯思維、和微觀(guān)理念方面著(zhù)手,詳細介紹了如何學(xué)好單片機這門(mén)應用技術(shù)的幾點(diǎn)經(jīng)驗之談。
引言
單片機誕生于20世紀70年代。所謂單片機是利用大規模集成電路技術(shù)把中央處理單元(Center Processing Unit,也即常稱(chēng)的CPU)和數據存儲器(RAM)、程序存儲器(ROM)及其他I/O通信口集成在一塊芯片上,構成一個(gè)最小的計算機系統,再加上了中斷單元,定時(shí)單元及A/D轉換等更復雜、更完善的電路,使得單片機的功能越來(lái)越強大,應用更廣泛[1]?,F在更多單片機的發(fā)展已經(jīng)進(jìn)入了嵌入式系統時(shí)代, 由于制造工藝的進(jìn)步,有如 VHDL、RTOS、CPLD、FPGA、DSP、ARM等這一系列可編程器件的體積越來(lái)越小、成本越來(lái)越低,而功能是越來(lái)越能滿(mǎn)足人們的需要。自上世紀80年代以來(lái),單片機技術(shù)在我國各個(gè)控制領(lǐng)域得到了廣泛應用,各個(gè)世界半導體公司都非??春弥袊@個(gè)龐大的市場(chǎng)而紛紛到中國來(lái)投資建廠(chǎng),如在蘇州就有日本的瑞薩、松下、美國的快捷等半導體公司在中的生產(chǎn)廠(chǎng)地。同時(shí)面對這一技術(shù)的不斷發(fā)展,我國大部分高校都已經(jīng)把單片機方面的課程作為學(xué)生的必修課,這為我國近些年來(lái)的科技、工業(yè)控制等方面的發(fā)展培養了大量人才,而且社會(huì )對此方面的人才需求還在不斷的增加。面對如此情況,作為在校學(xué)生,又該從何學(xué)起?如何學(xué)好這門(mén)課程呢?又怎樣才能不讓自己學(xué)了等于沒(méi)學(xué)呢?本文在多年實(shí)踐的基礎上,介紹自已的一些感受和經(jīng)驗。
1理解單片機的結構
對于一個(gè)初學(xué)者,最迷糊的就是對單片機芯片里面的結構的理解,小小的一個(gè)芯片為何能完成如此神奇的功能。
第一次從事電子方面的工作,也總對那黑黑的芯片里面感到不可思意的神奇。直到有一天,在檢修一臺日本二手電子市場(chǎng)里買(mǎi)來(lái)的程控交換機時(shí),發(fā)現里面有一塊黑東西上的黑膠已經(jīng)裂開(kāi),把它撬開(kāi)一看,里面就是一塊電路板,上面焊滿(mǎn)了密密麻麻的電子零件。終于有點(diǎn)明白,原來(lái)芯片也可以這樣做成。當然當時(shí)所見(jiàn)的那塊電路板是不能被稱(chēng)之為芯片的,那只是日本的電子制造公司為了防止別人抄襲而把整個(gè)電路板密封起來(lái)或其它原因,只引出幾個(gè)的引腳與其它電路連接。不過(guò)它可以讓人聯(lián)想到芯片的基本結構與此相類(lèi)似,如果把那些內眼看得見(jiàn)的電子零件再縮小一千倍或更小以至于能把所有電子零件做在一個(gè)硅片上,那也就成了名副其實(shí)的芯片了。我們不防以圖1所示的電路及電路板來(lái)做一個(gè)生動(dòng)形象的介紹。該圖是一個(gè)直流馬達可以正反兩個(gè)方向轉動(dòng)的電路,做成電路板并焊好電子元件后,經(jīng)測試沒(méi)有問(wèn)題就可以用黑膠(通常采用酚醛樹(shù)脂等材料)把所有電子元件封起來(lái),只留六個(gè)引腳來(lái)與外部電路連接,這樣看起來(lái)就好像是一個(gè)芯片。
知道了一般芯片的原理,同樣可以更進(jìn)一步想象單片機為什么會(huì )執行邏輯運算等功能,這就牽涉到數字電路和模擬電路的知識。其實(shí)不管一個(gè)單片機的功能是如何的強大,其只不過(guò)是把許多以微米,甚至是納米為單位級的數字的和模擬電子器件組成。為了形象的來(lái)說(shuō)明單片機內部的結構原理,這里不訪(fǎng)舉如圖2所示的跑馬燈電路來(lái)闡述。圖中電路表明的最終目的是讓LED依次輪流被點(diǎn)亮。首先是通過(guò)計數器對輸入脈沖計數,從0到15共16個(gè)脈沖為一個(gè)輪回,也即計數器的輸出依次為二進(jìn)制的0000B到1111B,再由四-十六譯碼器把計數器的結果解碼輸出,即依次置Y0到Y15由高電平變?yōu)楦唠娖?。當某一輸出為高電平時(shí),經(jīng)過(guò)反向器后,與此線(xiàn)路相連接的LED的陰極被拉為低電平從而點(diǎn)亮該發(fā)光二極管。這樣一來(lái),計數器和譯碼器就相當于單片機里的處理器與PC地址寄存器了,與譯碼器輸出腳相連的線(xiàn)就相當于地址線(xiàn),與LED負極相連的輸出線(xiàn)就相當于數據線(xiàn),每一條“地址線(xiàn)”都與8根“數據線(xiàn)”有一個(gè)交叉,每一個(gè)交叉就相當于存儲單元的每一個(gè)位。在這些交叉處是否要連通就相當于把程式燒錄到存儲器(ROM)里。最后總體來(lái)看就相當于一個(gè)只有16個(gè)地址的8位單片機。如果把LED換成圖中數碼管,改變圖中的二極管連接,在“單片機”通電和輸入時(shí)鐘脈沖后,就可以不停的來(lái)顯示數字了。
另外,要做到對單片機內部結果真正的了解,還必須得先要有很扎實(shí)的電路基礎、模擬電路、數字電路等方面的知識,否則可能就是空中樓閣。
2理清邏輯思維
學(xué)習單片機是最重要的一點(diǎn)就是不能糊涂,不能把邏輯關(guān)系搞得亂七八糟。對于初學(xué)單片機時(shí),要學(xué)會(huì )把一個(gè)程式的邏輯性關(guān)系用流程圖的形式清楚的表示出來(lái)。至于用來(lái)編寫(xiě)程式的單片機的語(yǔ)言是很簡(jiǎn)單的,不要把它想象得很神秘,不管是匯編語(yǔ)言、C語(yǔ)言、還是更高級的VC++和圖示化語(yǔ)言(如LABVIEW),都只不過(guò)是把我們清楚的邏輯思維告訴單片機處理器,并指令它將要被如何進(jìn)行邏輯操作。把單片機的指令看得很重要應該是我們大家在學(xué)習單片機時(shí)的一個(gè)最大的誤區,老是擔心指令記不住、不會(huì )用,這也是學(xué)習單片機還沒(méi)入門(mén)、上路的主要表現。其實(shí)這樣有什么擔心的呢,記不住就不要強求好了,把指令放在旁邊,當把邏輯關(guān)系清理好之后,再來(lái)對著(zhù)指令表確定哪個(gè)邏輯關(guān)系由哪些指令來(lái)完成,當一條指令運用得幾次后,根本就用不著(zhù)擔心不知道指令不會(huì )用了。退一步講,即使真的記不得指令,參照書(shū)本的指令用法也完全可行,現在的知識量是海量,全把所學(xué)的知識死記在腦子里肯定會(huì )把腦袋漲破。在寫(xiě)程序時(shí),只要程序的邏輯關(guān)系調理清楚了,寫(xiě)起來(lái)就好比做簡(jiǎn)單的翻譯工作,把邏輯關(guān)系翻譯成計算機語(yǔ)言來(lái)表示。如下圖3和圖4是一個(gè)簡(jiǎn)單的鍵掃描電路和程式流程圖,我們根據這個(gè)流程圖就很快能用目前非常普遍的C51匯編語(yǔ)言來(lái)寫(xiě)出這個(gè)程序。
KEY_SCAN:
PUSH A ;保存寄存器A
INC R1 ;
AND R1,00000011B
MOV R2,3
MOVC DPHL,TABLE ;取表首址
MOVC A,@DPHL+R1 ;讀取表中數據
AND A,00001111B ;保留低4位
MOV P1,A ;按所取表中數據由P1低4位輸出
CALL DELAY_TIME ;延時(shí)
MOV A,P1 ;讀取P1端口
AND A,11100000B ;保留P14、P16、P17
LOOP:
RLC A ;左移A一位到位寄存器“C”
JC R1,LOOP1 ;判斷位寄存器“C”是否為“0”
CALL KEY_CAL ;調用鍵碼計算子程序
LOOP1:
DJNE R2,LOOP ;判斷是否已移3位
POP A ;恢復寄存器A
RTI ;本次掃描結束
KEY_CAL: ;鍵碼計算子程序
… … …
RTS
DELAY_TIME: ;延時(shí)子程序
… … …
RTS
TABLE: ;鍵掃描輸出表
DB 11111110B
DB 11111101B
DB 11111011B
DB 11110111B
3對微觀(guān)世界的想象
曾經(jīng)在設計電路板時(shí),為了讓線(xiàn)路中的電流能流暢的通過(guò)線(xiàn)路,為了所設計的電路板能滿(mǎn)足各種測試條件下的安全標準,如UL標準要求最長(cháng)的電源地線(xiàn)不能過(guò)0.02歐姆(其測試條件是在20A的電流情況下測量它的功率P=I2R)。如果假如是0.02歐姆,通以20A的電流,那這條線(xiàn)路的發(fā)熱功率將會(huì )是8W。把電流看作是我們宏觀(guān)世界里的水,線(xiàn)路就好比一條水溝。要讓水在水溝里怎么流,這理所當然是很容易控制的了。如水在急轉彎的地方會(huì )起漩渦,會(huì )對急轉達彎的溝的對面產(chǎn)生沖擊。同樣在電路板上的線(xiàn)路如果存在急轉彎的情況,電流也會(huì )引起渦流,也會(huì )對線(xiàn)路的拐點(diǎn)處有一個(gè)沖擊作用而產(chǎn)生輻射。這樣一來(lái),在理解了這一原理之后,每一次電路板的設計完成之后,所有的測試都能一次通過(guò)??梢?jiàn)把微觀(guān)世界想象成宏觀(guān)世界相類(lèi)似的事物或過(guò)程是非常有幫助的?,F代電子世界,特別是微電子,要想看清他的真面目,只有在高清昕度的顯微鏡下才能看到他的外形,可是即使了解了它的外形,也只不過(guò)是知其然而不知其所以然,它的工作過(guò)程根本無(wú)法看得到。
現在單片機結構越來(lái)越復雜,集成度越來(lái)越高,存儲量越來(lái)越大,將來(lái)還可能采用分子級電子晶體管呢。它的運行速度也是如此的越來(lái)越快,現在已經(jīng)是采用納秒級來(lái)定義它的運行時(shí)間了,最長(cháng)的運行一條指令的時(shí)間最多不過(guò)一兩個(gè)微秒,簡(jiǎn)直就是比一閃而過(guò)還要少好多好多。既然我們可以在空間上利用放大鏡把外形放大后來(lái)了解,那么同樣可以在時(shí)間上把時(shí)間拉長(cháng)來(lái)解。不訪(fǎng)把一微秒當作時(shí)一分鐘或一小時(shí)來(lái)理解,這樣我們就不難理解CPU就如人一樣在處理某一條指令。比如指令“MOV A,01H”就是CPU把數據01H送到A累加器,在這個(gè)運送的過(guò)程就如人搬運東西的過(guò)程,這個(gè)過(guò)程的處理時(shí)間就是CPU處理一個(gè)指令的時(shí)間,通常稱(chēng)之為指令周期。有些時(shí)候單片機會(huì )出現對某個(gè)操作處理的時(shí)間不夠,如進(jìn)行數據采集時(shí),被采集的信號相對于單片機處理時(shí)間比較快就會(huì )出現數據遺失的情況,這就要求單片機的運行速度更快。如果沒(méi)有這處微觀(guān)時(shí)間的概念,就很難理解怎么會(huì )出現這種情況。
4結束語(yǔ)
單片機變化發(fā)展迅速,但萬(wàn)變不離其宗,只要清楚了它們的基本原理和構造思想,不管它怎么變,都能做到知其然知其所以然。
參考文獻:
1、匡忠輝 單片機原理及應用[M] 北京:機械工業(yè)出版社 2007年1月
評論