單片機原理

單片機原理

在線式實時控制計算機的原理方式
單片機原理是指一種在線式實時控制計算機的原理方式。在線式就是現場控制,需要的是有較強的抗幹擾能力,較低的成本,這也是和離線式計算機(比如家用PC)的主要區别。單片機就是一個微型電腦,它是靠程序工作的,并且可以修改。[1]
  • 中文名:單片機原理
  • 外文名:
  • 别名:
  • 表達式:
  • 提出者:
  • 适用領域:計算機

單片機

單片機到底是什麼呢?就是一個電腦,隻不過是微型的,麻雀雖小,五髒俱全:它内部也有和電腦功能類似的模塊,比如CPU,内存,并行總線,還有和硬盤作用相同的存儲器件,不同的是它的這些部件性能都相對我們的家用電腦弱很多,不過價錢也是低的,一般不超過10元......用它來做一些控制電器一類不是很複雜的工作足矣了。排煙罩VCD等等的家電裡面都可以看到它的身影!......它主要是作為控制部分的核心部件。

單片機是靠程序工作的,并且可以修改。通過不同的程序實現不同的功能,尤其是特殊的獨特的一些功能,這是别的器件需要費很大力氣才能做到的,有些則是花大力氣也很難做到的。一個不是很複雜的功能要是用美國50年代開發的74系列,或者60年代的CD4000系列這些純硬件來搞定的話,電路一定是一塊大PCB闆!但是如果要是用美國70年代成功投放市場的系列單片機,結果就會有天壤之别!隻因為單片機的通過你編寫的程序可以實現高智能,高效率,以及高可靠性!

由于單片機對成本是敏感的,所以目前占統治地位的軟件還是最低級彙編語言(近幾年,C語言也開始廣泛被應用),它是除了二進制機器碼以外最低級的語言了,既然這麼低級為什麼還要用呢?很多高級的語言已經達到了可視化編程的水平為什麼不用呢?原因很簡單,就是單片機沒有家用計算機那樣的CPU,也沒有像硬盤那樣的海量存儲設備。一個可視化高級語言編寫的小程序裡面即使隻有一個按鈕,也會達到幾十K的尺寸!對于家用PC的硬盤來講沒什麼,可是對于單片機來講是不能接受的。單片機在硬件資源方面的利用率必須很高才行,所以彙編雖然原始卻還是在大量使用。一樣的道理,如果把巨型計算機上的操作系統和應用軟件拿到家用PC上來運行,家用PC也是承受不了的。

目前最常用的單片機為MCS-51,是由美國INTEL公司(生産CPU的英特爾)生産的,89C51是這幾年在我國非常流行的單片機,它是由美國ATMEL公司開發生産的,其内核兼容MCS-51單片機。

單片微型計算機簡稱單片機,是典型的嵌入式微控制器(Microcontroller Unit),

單片機芯片

常用英文字母的縮寫MCU表示單片機,單片機又稱單片微控制器,它不是完成某一個邏輯功能的芯片,而是把一個計算機系統集成到一個芯片上。單片機由運算器,控制器,存儲器,相當于一個微型的計算機(最小系統),和計算機相比,單片機隻缺少了I/O設備。概括的講:一塊芯片就成了一台計算機。它的體積小、質量輕、價格便宜、為學習、應用和開發提供了便利條件。同時,學習使用單片機是了解計算機原理與結構的最佳選擇。它最早是被用在工業控制領域。

由于單片機在工業控制領域的廣泛應用,單片機由芯片内僅有CPU的專用處理器發展而來。最早的設計理念是通過将大量外圍設備和CPU集成在一個芯片中,使計算機系統更小,更容易集成進複雜的而對體積要求嚴格的控制設備當中。

INTEL的8080是最早按照這種思想設計出的處理器,當時的單片機都是8位或4位的。其中最成功的是INTEL的8031,此後在8031上發展出了MCS51系列單片機系統。因為簡單可靠而性能不錯獲得了很大的好評。盡管2000年以後ARM已經發展出了32位的主頻超過300M的高端單片機,直到目前基于8031的單片機還在廣泛的使用。在很多方面單片機比專用處理器更适合應用于嵌入式系統,因此它得到了廣泛的應用。事實上單片機是世界上數量最多處理器,随着單片機家族的發展壯大,單片機和專用處理器的發展便分道揚镳。

現代人類生活中所用的幾乎每件電子和機械産品中都會集成有單片機。手機、電話、計算器、家用電器、電子玩具、掌上電腦以及鼠标等電腦配件中都配有1-2部單片機。汽車上一般配備40多部單片機,複雜的工業控制系統上甚至可能有數百台單片機在同時工作!單片機的數量不僅遠超過PC機和其他計算的總和,甚至比人類的數量還要多。

單片機是指芯片本身,而單片機系統是為實現某一個控制應用需要由用戶設計的,是一個圍繞單片機芯片而組建的計算機應用系統,這是單片機應用系統。單片機開發系統是指單片機開發調試的工具。

單片機自問世以來,性能不斷提高和完善,其資源又能滿足很多應用場合的需要,加之單片機具有集成度高、功能強、速度快、體積小、功耗低、使用方便、價格低廉等特點,正在逐步取代現有的多片微機應用系統。單片機自動完成賦予它的任務的過程,也就是單片機執行程序的過程,即一條條執行的指令的過程,所謂指令就是把要求單片機執行的各種操作用的命令的形式寫下來,這是在設計人員賦予它的指令系統所決定的,一條指令對應着一種基本操作;單片機所能執行的全部指令,就是該單片機的指令系統,不同種類的單片機,其指令系統亦不同。

為使單片機能自動完成某一特定任務,必須把要解決的問題編成一系列指令(這些指令必須是選定單片機能識别和執行的指令),這一系列指令的集合就成為程序,程序需要預先存放在具有存儲功能的部件——存儲器中。存儲器由許多存儲單元(最小的存儲單位)組成,就像大樓房有許多房間組成一樣,指令就存放在這些單元裡,單元裡的指令取出并執行就像大樓房的每個房間的被分配到了唯一房間号一樣,每一個存儲單元也必須被分配到唯一的地址号,該地址号稱為存儲單元的地址,這樣隻要知道了存儲單元的地址,就可以找到這個存儲單元,其中存儲的指令就可以被取出,然後再被執行。

應用分類

單片機作為計算機發展的一個重要分支領域,根據目前發展情況,從不同角度單片機大緻可以分為通用型/專用型、總線型/非總線型及工控型/家電型。

通用型/專用型

這是按單片機适用範圍來區分的。例如,80C51是通用型單片機,它不是為某種專用途設計的;專用型單片機是針對一類産品甚至某一個産品設計生産的,例如為了滿足電子體溫計的要求,在片内集成ADC接口等功能的溫度測量控制電路。

總線/非總線型

這是按單片機是否提供并行總線來區分的。總線型單片機單片機普遍設置有并行地址總線、數據總線、控制總線,這些引腳用以擴展并行外圍器件都可通過串行口與單片機連接,另外,許多單片機已把所需要的外圍器件及外設接口集成一片内,因此在許多情況下可以不要并行擴展總線,大大減省封裝成本和芯片體積,這類單片機稱為非總線型單片機。

控制型/家電型

這是按照單片機大緻應用的領域進行區分的。一般而言,工控型尋址範圍大,運算能力強;用于家電的單片機多為專用型,通常是小封裝、低價格,外圍器件和外設接口集成度高。顯然,上述分類并不是惟一的和嚴格的。例如,80C51類單片機既是通用型又是總線型,還可以作工控用。

發展曆史

單片機誕生于1971年,經曆了SCM、MCU、SoC三大階段,早期的SCM單片機都是8位或4位的。其中最成功的是INTEL的8031,此後在8031上發展出了MCS51系列MCU系統。基于這一系統的單片機系統直到現在還在廣泛使用。随着工業控制領域要求的提高,開始出現了16位單片機,但因為性價比不理想并未得到很廣泛的應用。90年代後随着消費電子産品大發展,單片機技術得到了巨大提高。随着INTEL i960系列特别是後來的ARM系列的廣泛應用,32位單片機迅速取代16位單片機的高端地位,并且進入主流市場。

而傳統的8位單片機的性能也得到了飛速提高,處理能力比起80年代提高了數百倍。目前,高端的32位Soc單片機主頻已經超過300MHz,性能直追90年代中期的專用處理器,而普通的型号出廠價格跌落至1美元,最高端的型号也隻有10美元。

當代單片機系統已經不再隻在裸機環境下開發和使用,大量專用的嵌入式操作系統被廣泛應用在全系列的單片機上。而在作為掌上電腦和手機核心處理的高端單片機甚至可以直接使用專用的Windows和Linux操作系統。

主要階段

早期階段

SCM即單片微型計算機(Single Chip Microcomputer)階段,主要是尋求最佳的單片形态嵌入式系統的最佳體系結構。“創新模式”獲得成功,奠定了SCM與通用計算機完全不同的發展道路。在開創嵌入式系統獨立發展道路上,Intel公司功不可沒。

中期發展

MCU即微控制器(Micro Controller Unit)階段,主要的技術發展方向是:不斷擴展滿足嵌入式應用時,對象系統要求的各種外圍電路與接口電路,突顯其對象的智能化控制能力。它所涉及的領域都與對象系統相關,因此,發展MCU的重任不可避免地落在電氣、電子技術廠家。從這一角度來看,Intel逐漸淡出MCU的發展也有其客觀因素。在發展MCU方面,最著名的廠家當數Philips公司。

Philips公司以其在嵌入式應用方面的巨大優勢,将MCS-51從單片微型計算機迅速發展到微控制器。因此,當我們回顧嵌入式系統發展道路時,不要忘記Intel和Philips的曆史功績。

當前趨勢

SoC嵌入式系統(System on Chip)式的獨立發展之路,向MCU階段發展的重要因素,就是尋求應用系統在芯片上的最大化解決,因此,專用單片機的發展自然形成了SoC化趨勢。随着微電子技術、IC設計、EDA工具的發展,基于SoC的單片機應用系統設計會有較大的發展。因此,對單片機的理解可以從單片微型計算機、單片微控制器延伸到單片應用系統。

早期發展史

1971年intel公司研制出世界上第一個4位的微處理器;Intel公司的霍夫研制成功世界上第一塊4位微處理器芯片Intel 4004,标志着第一代微處理器問世,微處理器和微機時代從此開始。因發明微處理器,霍夫被英國《經濟學家》雜志列為“二戰以來最有影響力的7位科學家”之一。

1971年11月,Intel推出MCS-4微型計算機系統(包括4001 ROM芯片、4002 RAM芯片、4003移位寄存器芯片和4004微處理器)其中4004(下圖)包含2300個晶體管,尺寸規格為3mm×4mm,計算性能遠遠超過當年的ENIAC,最初售價為200美元。

1972年4月,霍夫等人開發出第一個8位微處理器Intel 8008。由于8008采用的是P溝道MOS微處理器,因此仍屬第一代微處理器。

1973年intel公司研制出8位的微處理器8080;1973年8月,霍夫等人研制出8位微處理器Intel 8080,以N溝道MOS電路取代了P溝道,第二代微處理器就此誕生。

主頻2MHz的8080芯片運算速度比8008快10倍,可存取64KB存儲器,使用了基于6微米技術的6000個晶體管,處理速度為0.64MIPS(Million Instructions Per Second)。

1975年4月,MITS發布第一個通用型Altair 8800,售價375美元,帶有1KB存儲器。這是世界上第一台微型計算機。

1976年intel公司研制出MCS-48系列8位的單片機,這也是單片機的問世。

Zilog公司于1976年開發的Z80微處理器,廣泛用于微型計算機和工業自動控制設備。當時,Zilog、Motorola和Intel在微處理器領域三足鼎立。

20世紀80年代初,Intel公司在MCS-48系列單片機的基礎上,推出了MCS-51系列8位高檔單片機。MCS-51系列單片機無論是片内RAM容量,I/O口功能,系統擴展方面都有了很大的提高。

硬件特性

1、主流單片機包括CPU、4KB容量的ROM、128B容量的RAM、2個16位定時/計數器、4個8位并行口、全雙工串口行口、ADC/DAC、SPI、I2C、ISP、IAP。

芯片

2、系統結構簡單,使用方便,實現模塊化;

3、單片機可靠性高,可工作到10^6~10^7小時無故障;

4、處理功能強,速度快。

5、低電壓,低功耗,便于生産便攜式産品

6、控制功能強

7、環境适應能力強。

基本結構

1.運算器

運算器由運算部件——算術邏輯單元(Arithmetic & Logical Unit,簡稱ALU)、累加器和寄存器等幾部分組成。ALU的作用是把傳來的數據進行算術或邏輯運算,輸入來源為兩個8位數據,分别來自累加器和數據寄存器。ALU能完成對這兩個數據進行加、減、與、或、比較大小等操作,最後将結果存入累加器。例如,兩個數6和7相加,在相加之前,操作數6放在累加器中,7放在數據寄存器中,當執行加法指令時,ALU即把兩個數相加并把結果13存入累加器,取代累加器原來的内容6。

運算器有兩個功能:

(1)執行各種算術運算。

(2)執行各種邏輯運算,并進行邏輯測試,如零值測試或兩個值的比較。

運算器所執行全部操作都是由控制器發出的控制信号來指揮的,并且,一個算術操作産生一個運算結果,一個邏輯操作産生一個判決。

2.控制器

控制器由程序計數器、指令寄存器、指令譯碼器、時序發生器和操作控制器等組成,是發布命令的“決策機構”,即協調和指揮整個微機系統的操作。其主要功能有:

(1)從内存中取出一條指令,并指出下一條指令在内存中的位置。

(2)對指令進行譯碼和測試,并産生相應的操作控制信号,以便于執行規定的動作。

(3)指揮并控制CPU、内存和輸入輸出設備之間數據流動的方向。

微處理器内通過内部總線把ALU、計數器、寄存器和控制部分互聯,并通過外部總線與外部的存儲器、輸入輸出接口電路聯接。外部總線又稱為系統總線,分為數據總線DB、地址總線AB和控制總線CB。通過輸入輸出接口電路,實現與各種外圍設備連接。

3.主要寄存器

(1)累加器A

圖1-2單片機組成框圖

累加器A是微處理器中使用最頻繁的寄存器。在算術和邏輯運算時它有雙功能:運算前,用于保存一個操作數;運算後,用于保存所得的和、差或邏輯運算結果。

(2)數據寄存器DR

數據寄存器通過數據總線向存儲器和輸入/輸出設備送(寫)或取(讀)數據的暫存單元。它可以保存一條正在譯碼的指令,也可以保存正在送往存儲器中存儲的一個數據字節等等。

(3)指令寄存器IR和指令譯碼器ID

指令包括操作碼和操作數。

指令寄存器是用來保存當前正在執行的一條指令。當執行一條指令時,先把它從内存中取到數據寄存器中,然後再傳送到指令寄存器。當系統執行給定的指令時,必須對操作碼進行譯碼,以确定所要求的操作,指令譯碼器就是負責這項工作的。其中,指令寄存器中操作碼字段的輸出就是指令譯碼器的輸入。

(4)程序計數器PC

PC用于确定下一條指令的地址,以保證程序能夠連續地執行下去,因此通常又被稱為指令地址計數器。在程序開始執行前必須将程序的第一條指令的内存單元地址(即程序的首地址)送入PC,使它總是指向下一條要執行指令的地址。

(5)地址寄存器AR

地址寄存器用于保存當前CPU所要訪問的内存單元或I/O設備的地址。由于内存與CPU之間存在着速度上的差異,所以必須使用地址寄存器來保持地址信息,直到内存讀/寫操作完成為止。

顯然,當CPU向存儲器存數據、CPU從内存取數據和CPU從内存讀出指令時,都要用到地址寄存器和數據寄存器。同樣,如果把外圍設備的地址作為内存地址單元來看的話,那麼當CPU和外圍設備交換信息時,也需要用到地址寄存器和數據寄存器。

應用範圍

目前單片機滲透到我們生活的各個領域,幾乎很難找到哪個領域沒有單片機的蹤迹。導彈的導航裝置,飛機上各種儀表的控制,計算機的網絡通訊與數據傳輸,工業自動化過程的實時控制和數據處理,廣泛使用的各種智能IC卡,民用豪華轎車的安全保障系統,錄像機、攝像機、全自動洗衣機的控制,以及程控玩具、電子寵物等等,這些都離不開單片機。更不用說自動控制領域的機器人、智能儀表、醫療器械以及各種智能機械了。因此,單片機的學習、開發與應用将造就一批計算機應用與智能化控制的科學家、工程師。

單片機廣泛應用于儀器儀表、家用電器、醫用設備、航空航天、專用設備的智能化管理及過程控制等領域,大緻可分如下幾個範疇:

智能儀器

單片機具有體積小、功耗低、控制功能強、擴展靈活、微型化和使用方便等優點,廣泛應用于儀器儀表中,結合不同類型的傳感器,可實現諸如電壓、電流、功率、頻率、濕度、溫度、流量、速度、厚度、角度、長度、硬度、元素、壓力等物理量的測量。采用單片機控制使得儀器儀表數字化、智能化、微型化,且功能比起采用電子或數字電路更加強大。

例如精密的測量設備(電壓表、功率計,示波器,各種分析儀)。

工業控制

單片機具有體積小、控制功能強、功耗低、環境适應能力強、擴展靈活和使用方便等優點,用單片機可以構成形式多樣的控制系統、數據采集系統、通信系統、信号檢測系統、無線感知系統、測控系統、機器人等應用控制系統。例如工廠流水線的智能化管理,電梯智能化控制、各種報警系統,與計算機聯網構成二級控制系統等。

家用電器

現在的家用電器廣泛采用了單片機控制,從電飯煲、洗衣機、電冰箱、空調機、彩電、其他音響視頻器材、再到電子秤量設備和白色家電等。

網絡和通信

現代的單片機普遍具備通信接口,可以很方便地與計算機進行數據通信,為在計算機網絡和通信設備間的應用提供了極好的物質條件,從手機,電話機、小型程控交換機、樓宇自動通信呼叫系統、列車無線通信、再到日常工作中随處可見的移動電話,集群移動通信,無線電對講機等。

醫用設備領域

單片機在醫用設備中的用途亦相當廣泛,例如醫用呼吸機,各種分析儀,監護儀,超聲診斷設備及病床呼叫系統等等。

模塊化系統

某些專用單片機設計用于實現特定功能,從而在各種電路中進行模塊化應用,而不要求使用人員了解其内部結構。如音樂集成單片機,看似簡單的功能,微縮在純電子芯片中(有别于磁帶機的原理),就需要複雜的類似于計算機的原理。如:音樂信号以數字的形式存于存儲器中(類似于ROM),由微控制器讀出,轉化為模拟音樂電信号(類似于聲卡)。

在大型電路中,這種模塊化應用極大地縮小了體積,簡化了電路,降低了損壞、錯誤率,也方便于更換。

汽車電子

單片機在汽車電子中的應用非常廣泛,例如汽車中的發動機控制器,基于CAN總線的汽車發動機智能電子控制器、GPS導航系統、abs防抱死系統、制動系統、胎壓檢測等。

此外,單片機在工商、金融、科研、教育、電力、通信、物流和國防航空航天等領域都有着十分廣泛的用途。

學習方法

基礎理論

基礎理論知識包括模拟電路、數字電路和C語言知識。模拟電路和數字電路屬于抽象學科,要把它學好還得費點精神。在你學習單片機之前,覺得模拟電路和數字電路基礎不好的話,不要急着學習單片機,應該先回顧所學過的模拟電路和數字電路知識,為學習單片機加強基礎。否則,你的單片機學習之路不僅會很艱難和漫長,還可能半途而廢。筆者始終認為,紮實的電子技術基礎是學好單片機的關鍵,直接影響單片機學習入門的快慢。有些同學覺得單片機很難,越學越複雜,最後學不下去了。有的同學看書時似乎明白了,可是動起手來卻一塌糊塗,究其原因就是電子技術基礎沒有打好,首先被表面知識給困惑了。

單片機屬于數字電路,其概念、術語、硬件結構和原理都源自數字電路,如果數字電路基礎紮實,對複雜的單片機硬件結構和原理就能容易理解,就能輕松地邁開學習的第一步,自信心也會樹立起來。相反,基礎不好,這個看不懂那個也弄不明白,越學問題越多,越學越沒有信心。如果你覺得單片機很難,那就應該先放下單片機教材,去重溫數字電路,搞清楚觸發器、寄存器、門電路、COMS電路、時序邏輯和時序圖、進制轉換等理論知識。理解了這些知識之後再去看看單片機的結構和原理,我想你會大徹大悟,信心倍增。

模拟電路是電子技術最基礎的學科,她讓你知道什麼是電阻、電容、電感、二極管、三極管、場效應管、放大器等等以及它們的工作原理和在電路中的作用,這是學習電子技術必須掌握的基礎知識。一般是先學習模拟電路再去學習數字電路。紮實的模拟電路基礎不僅讓你容易看懂别人設計的電路,而且讓你的設計的電路更可靠,提高産品質量。

單片機的學習離不開編程,在所有的程序設計中C語言運用的最為廣泛。C語言知識并不難,沒有任何編程基礎的人都可以學,在我看來,初中生、高中生、中專生、大學生都能學會。當然,數學基礎好、邏輯思維好的人學起來相對輕松一些。C語言需要掌握的知識就那麼3個條件判斷語句、3個循環語句、3個跳轉語句和1個開關語句。别小看這10個語句,用他們組合形成的邏輯要多複雜有多複雜。學習時要一條語句一條語句的學,學一條活用一條,全部學過用過這些關鍵語句後,相信你的C基礎建立了。

當基礎打好以後,你會感覺到單片機不再難學了,而且越學越起勁。當單片機乖乖的依照你的邏輯思維和算法去執行指令,實現預期控制效果的時候,成就感會讓你信心十足、夜以續日、廢寝忘食的投入到單片機的世界裡。可以這麼說,紮實的電子技術基礎和C語言基礎能增強學習單片機信心,較快掌握單片機技術。

實驗實踐

這是真正學習單片機的過程,既讓人興奮又讓人疲憊,既讓人無奈又讓人不服,既讓人孤獨又讓人充實,既讓人氣憤又讓人欣慰,既有失落感又有成就感。其中的酸甜苦辣隻有學過的人深有體會。思想上要有刻苦學習的決心,硬件上要有一套完整的學習開發工具,軟件上要注重理論和實踐相結合。

1.有刻苦學習的決心

首先,明确學習目的。先認真回答兩個問題:我學單片機來做什麼?需要多長時間把它學會?這是你學單片機的動力。沒有動力,我想你堅持不了多久。其次,端正學習心态。單片機學習過程是枯燥乏味、孤獨寂寞的過程。要知道,學習知識沒有捷徑,隻有循序漸進,腳踏實地,一步一個腳印,才能學到真功夫。再次,要多動腦勤動手。單片機的學習具有很強的實踐性,是一門很注重實際動手操作的技術學科。不動手實踐你是學不會單片機的。最後,虛心交流。在單片機學習過程中每個人都會遇到無數不能解決的問題,需要你向有經驗的過來人虛心求教,否則,一味的自己埋頭摸索會走許多彎路,浪費很多時間。

2.有一套完整的學習開發工具

學習單片機是需要成本的。必須有一台電腦、一塊單片機開發闆(如果開發闆不能直接下載程序代碼的話還得需要一個編程器)、一套視頻教程、一本單片機教材和一本C語言教材。電腦是用來編寫和編譯程序,并将程序代碼下載到單片機上;開發闆用來運行單片機程序,驗證實際效果;視頻教程就是手把手教你單片機開發環境的使用、單片機編程和調試。對于單片機初學者來說,視頻教程必須看,要不然,哪怕把教材看了幾遍,還是不知道如何下手,尤其是院校裡的單片機教材,學了之後,面對真正的單片機時可能還是束手無策;單片機教材和C語言教材是理論學習資料,備忘備查。不要為了節約成本不用開發闆而光用Protur軟件仿真調試,這和紙上談兵沒什麼區别。

3.要注重理論和實踐相結合

單片機C語言編程理論知識并不深奧,光看書不動手也能明白。但在實際編程的時候就沒那麼簡單了。一個程序的形成不僅需要有C語言知識,更多需要融入你個人的編程思路和算法。編程思路和算法決定一個程序的優劣,是單片機編程的大問題,隻有在實際動手編寫的時候才會有深切的感悟。一個程序能否按照你的意願正常運行就要看你的思路和算法是否正确、合理。如果程序不正常則要反複調試(檢查、修改思路和算法),直到成功。這個過程耗時、費腦、疲精神,意志不堅強者往往被絆倒在這裡半途而廢。

學習編寫程序應該按照以下過程學習,效果會更好。看到例程題目先試着構思自己的編程思路,然後再看教材或視頻教程裡的代碼,研究人家的編程思路,注意與自己思路的差異;接下來就照搬人家的思路親自動手編寫這個程序,領會其中每一條語句的作用;對有疑問的地方試着按照自己的思路修改程序,比較程序運行效果,領會其中的奧妙。每一個例程都堅持按照這個過程學習,你很快會找到編程的感覺,取其精華去其糟粕,久而久之會形成你獨特的編程思想。

當然,剛開始,看别人的程序源代碼就像看天書一樣,隻要硬着頭皮看,看到不懂的關鍵字和語句就翻書查閱、對照。隻要能堅持下來,學習收獲會事半功倍。在實踐過程中不僅要學會别人的例程,還要在别人的程序上改進和拓展,讓程序産生更強大的功能。同時,還要懂得通過查閱芯片數據手冊(DATASHEET)裡有關芯片命令和數據的讀寫時序來核對别人例程的可靠性,如果你覺得例程不可靠就把它修改過來,成為是你自己的程序。不僅如此,自己應該經常找些項目來做,以鞏固所學的知識和積累更多的經驗。

硬件設計

當編寫自己的程序信手拈來、閱讀别人的程序能夠發現問題的時候,說明你的單片機編程水平相當不錯了。接下來就應該研究硬件了。硬件設計包括電路原理設計和PCB闆設計。學習做硬件要比學習做軟件麻煩,成本更高,周期更長。但是,學習單片機的最終目的是做産品開發----軟件和硬件相結合形成完整的控制系統。所以,做硬件也是學習單片機技術的一個必學内容。

電路原理設計涉及到各種芯片的應用,而這些芯片外圍電路的設計、典型應用電路和與單片機的連接等在芯片數據手冊(DATASHEET)都能找到答案,前提是要看得懂全英文的數據手冊。否則,照搬别人的設計永遠落在别人的後面,你做的産品就沒有創意。電子技術領域的第一手資料(DATASHEET)都是英文,從第一手資料裡你所獲得的知識可能是在教科書、網絡文檔和課外讀物等所沒有的知識。雖然有些資料也都是在DATASHEET的基礎上撰寫的,但内容不全面,甚至存在翻譯上的遺漏和錯誤。當然,閱讀DATASHEET需要具備一定的英文閱讀能力,這也是阻礙單片機學習者晉級的絆腳石。良好的英文閱讀能力能讓你在單片機技術知識的海洋裡自由遨遊。

做PCB闆就比較簡單了。隻要懂得使用Protel軟件或AltimDesigner軟件就沒問題了。但要想做的闆子布局美觀、布線合理還得費一番功夫了。

娴熟的單片機C語言編程、會使用Protel軟件或AltimDesigner軟件設計PCB闆和具備一定的英文閱讀能力,你就是一個遇強則強的單片機高手了。

抗幹擾

在提高硬件系統抗幹擾能力的同時,軟件抗幹擾以其設計靈活、節省硬件資源、可靠性好越來越受到重視。下面以MCS-51單片機系統為例,對微機系統軟件抗幹擾方法進行研究。

軟件設計

在工程實踐中,軟件抗幹擾研究的内容主要是:一、消除模拟輸入信号的噪聲(如數字濾波技術);二、程序運行混亂時使程序重入正軌的方法。本文針對後者提出了幾種有效的軟件抗幹擾方法。

指令冗餘

CPU取指令過程是先取操作碼,再取操作數。當PC受幹擾出現錯誤,程序便脫離正常軌道“亂飛”,當亂飛到某雙字節指令,若取指令時刻落在操作數上,誤将操作數當做操作碼,程序将出錯。若“飛”到了三字節指令,出錯機率更大。

在關鍵地方人為插入一些單字節指令,或将有效單字節指令重寫稱為指令冗餘。通常是在雙字節指令和三字節指令後插入兩個字節以上的NOP。這樣即使亂飛程序飛到操作數上,由于空操作指令NOP的存在,避免了後面的指令被當作操作數執行,程序自動納入正軌。

此外,對系統流向起重要作用的指令如RET、RETI、LCALL、LJMP、JC等指令之前插入兩條NOP,也可将亂飛程序納入正軌,确保這些重要指令的執行。

攔截技術

所謂攔截,是指将亂飛的程序引向指定位置,再進行出錯處理。通常用軟件陷阱來攔截亂飛的程序。因此先要合理設計陷阱,其次要将陷阱安排在适當的位置。

(1)軟件陷阱的設計

當亂飛程序進入非程序區,冗餘指令便無法起作用。通過軟件陷阱,攔截亂飛程序,将其引向指定位置,再進行出錯處理。軟件陷阱是指用來将捕獲的亂飛程序引向複位入口地址0000H的指令。通常在EPROM中非程序區填入以下指令作為軟件陷阱:

(2)陷阱的安排

最後一條應填入020000,當亂飛程序落到此區,即可自動入軌。在用戶程序區各模塊之間的空餘單元也可填入陷阱指令。當使用的中斷因幹擾而開放時,在對應的中斷服務程序中設置軟件陷阱,能及時捕獲錯誤的中斷。如某應用系統雖未用到外部中斷1,外部中斷1的中斷服務程序可為如下形式:

NOPNOPRETI返回指令可用“RETI”,也可用“LJMP 0000H”。如果故障診斷程序與系統自恢複程序的設計可靠、完善,用“LJMP 0000H”作返回指令可直接進入故障診斷程序,盡早地處理故障并恢複程序的運行。

考慮到程序存貯器的容量,軟件陷阱一般1K空間有2-3個就可以進行有效攔截。

軟件“看門狗”技術

若失控的程序進入“死循環”,通常采用“看門狗”技術使程序脫離“死循環”。通過不斷檢測程序循環運行時間,若發現程序循環時間超過最大循環運行時間,則認為系統陷入“死循環”,需進行出錯處理。

“看門狗”技術可由硬件實現,也可由軟件實現。在工業應用中,嚴重的幹擾有時會破壞中斷方式控制字,關閉中斷。則系統無法定時“喂狗”,硬件看門狗電路失效。而軟件看門狗可有效地解決這類問題。

筆者在實際應用中,采用環形中斷監視系統。用定時器T0監視定時器T1,用定時器T1監視主程序,主程序監視定時器T0。采用這種環形結構的軟件“看門狗”具有良好的抗幹擾性能,大大提高了系統可靠性。對于需經常使用T1定時器進行串口通訊的測控系統,則定時器T1不能進行中斷,可改由串口中斷進行監控(如果用的是MCS-52系列單片機,也可用T2代替T1進行監視)。這種軟件“看門狗”監視原理是:在主程序、T0中斷服務程序、T1中斷服務程序中各設一運行觀測變量,假設為MWatch、T0Watch、T1Watch,主程序每循環一次,MWatch加1,同樣T0、T1中斷服務程序執行一次,T0Watch、T1Watch加1。在T0中斷服務程序中通過檢測T1Watch的變化情況判定T1運行是否正常,在T1中斷服務程序中檢測MWatch的變化情況判定主程序是否正常運行,在主程序中通過檢測T0Watch的變化情況判别T0是否正常工作。若檢測到某觀測變量變化不正常,比如應當加1而未加1,則轉到出錯處理程序作排除故障處理。當然,對主程序最大循環周期、定時器T0和T1定時周期應予以全盤合理考慮。限于篇幅不贅述。

硬件技術

單片機系統因幹擾複位或掉電後複位均屬非正常複位,應進行故障診斷并能自動恢複非正常複位前的狀态。

非正常複位的識别

程序的執行總是從0000H開始,導緻程序從0000H開始執行有四種可能:一、系統開機上電複位;二、軟件故障複位;三、看門狗超時未喂狗硬件複位;四、任務正在執行中掉電後來電複位。四種情況中除第一種情況外均屬非正常複位,需加以識别。

(1)硬件複位與軟件複位的識别

此處硬件複位指開機複位與看門狗複位,硬件複位對寄存器有影響,如複位後PC=0000H,P=07H,PSW=00H等。而軟件複位則對SP、SPW無影響。故對于微機測控系統,當程序正常運行時,将SP設置地址大于07H,或者将PSW的第5位用戶标志位在系統正常運行時設為1。那麼系統複位時隻需檢測PSW.5标志位或SP值便可判此是否硬件複位。

由于硬件複位時片内RAM狀态是随機的,而軟件複位片内RAM則可保持複位前狀态,因此可選取片内某一個或兩個單元作為上電标志。設40H用來做上電标志,上電标志字為78H,若系統複位後40H單元内容不等于78H,則認為是硬件複位,否則認為是軟件複位,轉向出錯處理。若用兩個單元作上電标志,則這種判别方法的可靠性更高。

(2)開機複位與看門狗故障複位的識别

開機複位與看門狗故障複位因同屬硬件複位,所以要想予以正确識别,一般要借助非易失性RAM或者EEROM。當系統正常運行時,設置一可掉電保護的觀測單元。當系統正常運行時,在定時喂狗的中斷服務程序中使該觀測單元保持正常值(設為AAH),而在主程中将該單元清零,因觀測單元掉電可保護,則開機時通過檢測該單元是否為正常值可判斷是否看門狗複位。

(3)正常開機複位與非正常開機複位的識别

識别測控系統中因意外情況如系統掉電等情況引起的開機複位與正常開機複位,對于過程控制系統尤為重要。如某以時間為控制标準的測控系統,完成一次測控任務需1小時。在已執行測控50分鐘的情況下,系統電壓異常引起複位,此時若系統複位後又從頭開始進行測控則會造成不必要的時間消耗。因此可通過一監測單元對當前系統的運行狀态、系統時間予以監控,将控制過程分解為若幹步或若幹時間段,每執行完一步或每運行一個時間段則對監測單元置為關機允許值,不同的任務或任務的不同階段有不同的值,若系統正在進行測控任務或正在執某時間段,則将監測單元置為非正常關機值。那麼系統複位後可據此單元判系統原來的運行狀态,并跳到出錯處理程序中恢複系統原運行狀态。

非正常複位後系統自恢複運行的程序設計

對順序要求嚴格的一些過程控制系統,系統非正常複位否,一般都要求從失控的那一個模塊或任務恢複運行。所以測控系統要作好重要數據單元、參數的備份,如系統運行狀态、系統的進程值、當前輸入、輸出的值,當前時鐘值、觀測單元值等,這些數據既要定時備份,同時若有修改也應立即予以備份。

當在已判别出系統非正常複位的情況下,先要恢複一些必要的系統數據,如顯示模塊的初始化、片外擴展芯片的初始化等。其次再對測控系統的系統狀态、運行參數等予以恢複,包括顯示界面等的恢複。之後再把複位前的任務、參數、運行時間等恢複,再進入系統運行狀态。

應當說明的是,真實地恢複系統的運行狀态需要極為細緻地對系統的重要數據予以備份,并加以數據可靠性檢查,以保證恢複的數據的可靠性。

其次,對多任務、多進程測控系統,數據的恢複需考慮恢複的次序問題。

系統基本初始化是指對芯片、顯示、輸入輸出方式等進行初始化,要注意輸入輸出的初始化不應造成誤動作。而複位前任務的初始化是指任務的執行狀态、運行時間等。

對于軟件抗幹擾的一些其它常用方法如數字濾波、RAM數據保護與糾錯等,限于篇幅,本文未作讨論。在工程實踐中通常都是幾種抗幹擾方法并用,互相補充完善,才能取得較好的抗幹擾效果。從根本上來說,硬件抗幹擾是主動的,而軟件是抗幹擾是被動的。細緻周到地分析幹擾源,硬件與軟件抗幹擾相結合,完善系統監控程序,設計一穩定可靠的單片機系統是完全可行的。

基礎知識

本段僅針對硬件設計人員和軟件設計人員,為了便于對硬件的理解要有一定的彙編語言基礎。

總線

我們知道,一個電路總是由元器件通過電線連接而成的,在模拟電路中,連線并不成為一個問題,因為各器件間一般是串行關系,各器件之間的連線并不很多,但計算機電路卻不一樣,它是以微處理器為核心,各器件都要與微處理器相連,各器件之間的工作必須相互協調,所以需要的連線就很多了,如果仍如同模拟電路一樣,在各微處理器和各器件間單獨連線,則線的數量将多得驚人,所以在微處理機中引入了總線的概念,各個器件共同享用連線,所有器件的8根數據線全部接到8根公用的線上,即相當于各個器件并聯起來,但僅這樣還不行,如果有兩個器件同時送出數據,一個為0,一個為1,那麼,接收方接收到的究竟是什麼呢?

這種情況是不允許的,所以要通過控制線進行控制,使器件分時工作,任何時候隻能有一個器件發送數據(可以有多個器件同時接收)。器件的數據線也就被稱為數據總線,器件所有的控制線被稱為控制總線。在單片機内部或者外部存儲器及其它器件中有存儲單元,這些存儲單元要被分配地址,才能使用,分配地址當然也是以電信号的形式給出的,由于存儲單元比較多,所以,用于地址分配的線也較多,這些線被稱為地址總線。

數據地址指令

這三者的本質都是一樣的——數字,或者說都是一串‘0’和‘1’組成的序列。換言之,地址、指令也都是數據。指令:由單片機芯片的設計者規定的一種數字,它與我們常用的指令助記符有着嚴格的一一對應關系,不可以由單片機的開發者更改。地址:是尋找單片機内部、外部的存儲單元、輸入輸出口的依據,内部單元的地址值已由芯片設計者規定好,不可更改,外部的單元可以由單片機開發者自行決定,但有一些地址單元是一定要有的(詳見程序的執行過程)。數據:這是由微處理機處理的對象,在各種不同的應用電路中各不相同,一般而言,被處理的數據可能有這麼幾種情況:

1.地址(如MOV DPTR,1000H),即地址1000H送入DPTR。

2.方式字或控制字(如MOV TMOD,#3),3即是控制字。

3.常數(如MOV TH0,#10H)10H即定時常數。

4.實際輸出值(如P1口接彩燈,要燈全亮,則執行指令:MOV P1,#0FFH,要燈全暗,則執行指令:MOV P1,#00H)這裡0FFH和00H都是實際輸出值。又如用于LED的字形碼,也是實際輸出的值。

理解了地址、指令的本質,就不難理解程序運行過程中為什麼會跑飛,會把數據當成指令來執行了。

P0/P2/P3功能

初學時往往對P0口、P2口和P3口的第二功能用法迷惑不解,認為第二功能和原功能之間要有一個切換的過程,或者說要有一條指令,事實上,各端口的第二功能完全是自動的,不需要用指令來轉換。如P3.6、P3.7分别是WR、RD信号,當微處理機外接RAM或有外部I/O口時,它們被用作第二功能,不能作為通用I/O口使用,隻要一微處理機一執行到MOVX指令,就會有相應的信号從P3.6或P3.7送出,不需要事先用指令說明。事實上‘不能作為通用I/O口使用’也并不是‘不能’而是(使用者)‘不會’将其作為通用I/O口使用。你完全可以在指令中按排一條SETB P3.7的指令,并且當單片機執行到這條指令時,也會使P3.7變為高電平,但使用者不會這麼去做,因為這通常會導緻系統的崩潰。

程序執行過程

單片機在通電複位後8051内的程序計數器(PC)中的值為‘0000’,所以程序總是從‘0000’單元開始執行,也就是說:在系統的ROM中一定要存在‘0000’這個單元,并且在‘0000’單元中存放的一定是一條指令。

堆棧

堆棧是一個區域,是用來存放數據的,這個區域本身沒有任何特殊之處,就是内部RAM的一部份,特殊的是它存放和取用數據的方式,即所謂的‘先進後出,後進先出’,并且堆棧有特殊的數據傳輸指令,即‘PUSH’和‘POP’,有一個特殊的專為其服務的單元,即堆棧指針SP,每當執一次PUSH指令時,SP就(在原來值的基礎上)自動加1,每當執行一次POP指令,SP就(在原來值的基礎上)自動減1。

由于SP中的值可以用指令加以改變,所以隻要在程序開始階段更改了SP的值,就可以把堆棧設置在規定的内存單元中,如在程序開始時,用一條MOV SP,#5FH指令,就是把堆棧設置在從内存單元60H開始的單元中。一般程序的開頭總有這麼一條設置堆棧指針的指令,因為開機時,SP的初始值為07H,這樣就使堆棧從08H單元開始往後,而08H到1FH這個區域正是8031的第二、三、四工作寄存器區,經常要被使用,這會造成數據的混亂。不同作者編寫程序時,初始化堆棧指令也不完全相同,這是作者的習慣問題。當設置好堆棧區後,并不意味着該區域成為一種專用内存,它還是可以象普通内存區域一樣使用,隻是一般情況下編程者不會把它當成普通内存用了。

開發過程

這裡所說的開發過程并不是一般書中所說的從任務分析開始,我們假設已設計并制作好硬件,下面就是編寫軟件的工作。在編寫軟件之前,首先要确定一些常數、地址,事實上這些常數、地址在設計階段已被直接或間接地确定下來了。如當某器件的連線設計好後,其地址也就被确定了,當器件的功能被确定下來後,其控制字也就被确定了。然後用文本編輯器(如EDIT、CCED等)編寫軟件,編寫好後,用編譯器對源程序文件編譯,查錯,直到沒有語法錯誤,除了極簡單的程序外,一般應用仿真機對軟件進行調試,直到程序運行正确為止。運行正确後,就可以寫片(将程序固化在EPROM中)。在源程序被編譯後,生成了擴展名為HEX的目标文件,一般編程器能夠識别這種格式的文件,隻要将此文件調入即可寫片。

常用類型

STC單片機

STC公司的單片機主要是基于8051内核,是新一代增強型單片機,指令代碼完全兼容傳統8051,速度快8~12倍,帶ADC,4路PWM,雙串口,有全球唯一ID号,加密性好,抗幹擾強.

PIC單片機:

是MICROCHIP公司的産品,其突出的特點是體積小,功耗低,精簡指令集,抗幹擾性好,可靠性高,有較強的模拟接口,代碼保密性好,大部分芯片有其兼容的FLASH程序存儲器的芯片.

EMC單片機

是台灣義隆公司的産品,有很大一部分與PIC 8位單片機兼容,且相兼容産品的資源相對比PIC的多,價格便宜,有很多系列可選,但抗幹擾較差.

ATMEL單片機(51單片機):

ATMEl公司的8位單片機有AT89、AT90兩個系列,AT89系列是8位Flash單片機,與8051系列單片機相兼容,靜态時鐘模式;AT90系列單片機是增強RISC結構、全靜态工作方式、内載在線可編程Flash的單片機,也叫AVR單片機.

PHLIPIS 51LPC系列單片機(51單片機):

PHILIPS公司的單片機是基于80C51内核的單片機,嵌入了掉電檢測、模拟以及片内RC振蕩器等功能,這使51LPC在高集成度、低成本、低功耗的應用設計中可以滿足多方面的性能要求.

HOLTEK單片機:

台灣盛揚半導體的單片機,價格便宜,種類較多,但抗幹擾較差,适用于消費類産品.

TI公司單片機(51單片機):

德州儀器提供了TMS370和MSP430兩大系列通用單片機.TMS370系列單片機是8位CMOS單片機,具有多種存儲模式、多種外圍接口模式,适用于複雜的實時控制場合;MSP430系列單片機是一種超低功耗、功能集成度較高的16位低功耗單片機,特别适用于要求功耗低的場合

松翰單片機(SONIX):

是台灣松翰公司的單片,大多為8位機,有一部分與PIC 8位單片機兼容,價格便宜,系統時鐘分頻可選項較多,有PMW ADC内振内部雜訊濾波。缺點RAM空間過小,抗幹擾較好。

三星單片機:

三星單片機有KS51和KS57系列4位單片機,KS86和KS88系列8位單片機,KS17系列16位單片機和KS32系列32位單片機,三星還為ARM公司生産ARM單片機,常見的S344b0等.三星單片機為OTP型ISP在片編程功能。

華幫單片機:

華幫單片機屬于8051類單片機,它們的W78系列與标準的8051兼容,W77系列為增強型51,對8051的時序做了改進.同樣時鐘下速度快了不少。在4位機上華幫有921系列,帶LCD驅動的741系列。在32位機方面,華幫使用了惠普公司PA-RISC單片機技術,生産低位32位RISC單片機。

SST單片機:

美國SST公司推出的SST89系列單片機為标準的51系列單片機,包括SST89E/V52RD2,SST89E/V54RD2,SST89E/V58RD2,SST89E/V554RC,SST89E/V564RD等。它與8052系列單片機兼容。提供系統在線編程(ISP功能)。内部flash擦寫次數1萬次以上,程序保存時間可達100年。

還有很多優秀的單片機生産企業這裡沒有收集,每個企業都有自己的特點,大家根據需要選擇單片機,在完全實現功能的前提下追求低價位,當然并不是這樣最好,實際中選擇單片機跟開發者的應用習慣和開發經驗是密不可分的。

攻擊技術

目前,攻擊單片機主要有四種技術,分别是:

(1)軟件攻擊

該技術通常使用處理器通信接口并利用協議、加密算法或這些算法中的安全漏洞來進行攻擊。軟件攻擊取得成功的一個典型事例是對早期ATMEL AT89C系列單片機的攻擊。攻擊者利用了該系列單片機擦除操作時序設計上的漏洞,使用自編程序在擦除加密鎖定位後,停止下一步擦除片内程序存儲器數據的操作,從而使加過密的單片機變成沒加密的單片機,然後利用編程器讀出片内程序。

(2)電子探測攻擊

該技術通常以高時間分辨率來監控處理器在正常操作時所有電源和接口連接的模拟特性,并通過監控它的電磁輻射特性來實施攻擊。因為單片機是一個活動的電子器件,當它執行不同的指令時,對應的電源功率消耗也相應變化。這樣通過使用特殊的電子測量儀器和數學統計方法分析和檢測這些變化,即可獲取單片機中的特定關鍵信息。

(3)過錯産生技術

該技術使用異常工作條件來使處理器出錯,然後提供額外的訪問來進行攻擊。使用最廣泛的過錯産生攻擊手段包括電壓沖擊和時鐘沖擊。低電壓和高電壓攻擊可用來禁止保護電路工作或強制處理器執行錯誤操作。時鐘瞬态跳變也許會複位保護電路而不會破壞受保護信息。電源和時鐘瞬态跳變可以在某些處理器中影響單條指令的解碼和執行。

(4)探針技術

該技術是直接暴露芯片内部連線,然後觀察、操控、幹擾單片機以達到攻擊目的。為了方便起見,人們将以上四種攻擊技術分成兩類,一類是侵入型攻擊(物理攻擊),這類攻擊需要破壞封裝,然後借助半導體測試設備、顯微鏡和微定位器,在專門的實驗室花上幾小時甚至幾周時間才能完成。所有的微探針技術都屬于侵入型攻擊。另外三種方法屬于非侵入型攻擊,被攻擊的單片機不會被物理損壞。在某些場合非侵入型攻擊是特别危險的,但是因為非侵入型攻擊所需設備通常可以自制和升級,因此非常廉價。

大部分非侵入型攻擊需要攻擊者具備良好的處理器知識和軟件知識。與之相反,侵入型的探針攻擊則不需要太多的初始知識,而且通常可用一整套相似的技術對付寬範圍的産品。

學習

一、單片機與嵌入式系統概述:包括嵌入式系統概念、單片機的特點、應用領域和發展趨勢、市場主流單片機性能比較與選型、常用51核單片機介紹、業内通用嵌入式系統開發方法和流程、開發闆及相關開發工具的介紹和使用等;

二、51單片機架構及基本資源的使用:包括單片機工作原理介紹、51單片機架構介紹、單片機最小系統介紹、51單片機基本資源如并口、中斷、時鐘與複位、串口等的熟練使用等;

三、單片機基本資源擴展設計:包括存儲器擴展設計、可編程和不可編程I/O接口擴展設計、I2C總線的模拟設計等;

四、輸入輸出設備的設計:包括獨立式按鍵和矩陣鍵盤的各種輸入方法、數碼管及液晶顯示器的接口設計、蜂鳴器的設計;

五、輸入通道和輸出通道的設計:包括一定模拟和數字信号量的輸入、頻率量的輸入方法、A/D轉換原理與器件選型及其與單片機的接口設計、數字與模拟量的輸出方法、功率驅動相關知識、D/A轉換原理與器件選型及其與單片機的接口設計等;

六、單片機軟硬件設計和調試經驗:各種軟件開發和設計技巧、調試經驗等;

七、開發環境和開發工具介紹:Keil uVision2集成開發環境的使用與軟調試等;

八、軟硬件系統集成和調試方法,技術文檔的編寫規範

應用領域

單片機廣泛應用于儀器儀表、家用電器、醫用設備、航空航天、專用設備的智能化管理及過程控制等領域,大緻可分如下幾個範疇:

1.在智能儀器儀表上的應用

單片機具有體積小、功耗低、控制功能強、擴展靈活、微型化和使用方便等優點,廣泛應用于儀器儀表中,結合不同類型的傳感器,可實現諸如電壓、功率、頻率、濕度、溫度、流量、速度、厚度、角度、長度、硬度、元素、壓力等物理量的測量。采用單片機控制使得儀器儀表數字化、智能化、微型化,且功能比起采用電子或數字電路更加強大。例如精密的測量設備(功率計,示波器,各種分析儀)。

2.在工業控制中的應用

用單片機可以構成形式多樣的控制系統、數據采集系統。例如工廠流水線的智能化管理,電梯智能化控制、各種報警系統,與計算機聯網構成二級控制系統等。

3.在家用電器中的應用

可以這樣說,從電飯褒、洗衣機、電冰箱、空調機、彩電、其他音響視頻器材、再到電子秤量設備,五花八門,無所不在。

4.在計算機網絡和通信領域中的應用

現代的單片機普遍具備通信接口,可以很方便地與計算機進行數據通信,為在計算機網絡和通信設備間的應用提供了極好的物質條件,現在的通信設備基本上都實現了單片機智能控制,從手機,電話機、小型程控交換機、樓宇自動通信呼叫系統、列車無線通信、再到日常工作中随處可見的移動電話,集群移動通信,無線電對講機等。

5.單片機在醫用設備領域中的應用

單片機在醫用設備中的用途亦相當廣泛,例如醫用呼吸機,各種分析儀,監護儀,超聲診斷設備及病床呼叫系統等等。

此外,單片機在工商,金融,科研、教育,國防航空航天等領域都有着十分廣泛的用途。

相關詞條

相關搜索

其它詞條