1. C語(yǔ)言和匯編語(yǔ)言在開發(fā)單片機(jī)時(shí)各有哪些優(yōu)缺點(diǎn)?
匯編語(yǔ)言是一種用文字助記符來(lái)表示機(jī)器指令的符號(hào)語(yǔ)言,是最接近機(jī)器碼的一種語(yǔ)言。其主要優(yōu)點(diǎn)是占用資源少、程序執(zhí)行效率高。但是不同的CPU, 其匯編語(yǔ)言可能有所差異,所以不易移植。
C語(yǔ)言是一種結(jié)構(gòu)化的高級(jí)語(yǔ)言。其優(yōu)點(diǎn)是可讀性好,移植容易,是普遍使用的一種計(jì)算機(jī)語(yǔ)言。缺點(diǎn)是占用資源較多,執(zhí)行效率沒(méi)有匯編高。
對(duì)于目前普遍使用的RISC 架構(gòu)的8bit MCU來(lái)說(shuō),其內(nèi)部ROM、RAM、 STACK 等資源都有限,如果使用C語(yǔ)言編寫,一條C語(yǔ)言指令編譯后,會(huì)變成很多條機(jī)器碼,很容易出現(xiàn)ROM空間不夠、堆棧溢出等問(wèn)題。而且一些單片機(jī)廠家也不一定能提供C編譯器。而匯編語(yǔ)言,一條指令就對(duì)應(yīng)一個(gè)機(jī)器碼,每一步執(zhí)行什么動(dòng)作都很清楚,并且程序大小和堆棧調(diào)用情況都容易控制,調(diào)試起來(lái)也比較方便。所以在單片機(jī)開發(fā)中,我們還是建議采用匯編語(yǔ)言比較好。
2. C或匯編語(yǔ)言可以用于單片機(jī),C++能嗎?
在單片機(jī)開發(fā)中,主要是匯編和C。
3. 搞單片機(jī)開發(fā),一定要會(huì) C 嗎?
匯編語(yǔ)言是一種用文字助記符來(lái)表示機(jī)器指令的符號(hào)語(yǔ)言,是最接近機(jī)器碼的一種語(yǔ)言。其主要優(yōu)點(diǎn)是占用資源少、程序執(zhí)行效率高。但是不同的CPU, 其匯編語(yǔ)言可能有所差異,所以不易移植。
C語(yǔ)言是一種編譯型程序設(shè)計(jì)語(yǔ)言,它兼顧了多種高級(jí)語(yǔ)言的特點(diǎn),并具備匯編語(yǔ)言的功能。C語(yǔ)言有功能豐富的庫(kù)函數(shù)、運(yùn)算速度快、編譯效率高、 有良好的可移植性,而且可以直接實(shí)現(xiàn)對(duì)系統(tǒng)硬件的控制。C語(yǔ)言是一種結(jié)構(gòu)化程序設(shè)計(jì)語(yǔ)言,它支持當(dāng)前程序設(shè)計(jì)中廣泛采用的由頂向下結(jié)構(gòu)化程序設(shè)計(jì)技術(shù)。
此外,C語(yǔ)言程序具有完善的模塊程序結(jié)構(gòu),從而為軟件開發(fā)中采用模塊化程序設(shè)計(jì)方法提供了有力的保障。因此,使用C語(yǔ)言進(jìn)行程序設(shè)計(jì)已成為軟件開發(fā)的一個(gè)主流。用C語(yǔ)言來(lái)編寫目標(biāo)系統(tǒng)軟件,會(huì)大大縮短開發(fā)周期,且明顯地增加軟件的可讀性,便于改進(jìn)和擴(kuò)充,從而研制出規(guī)模更大、性能更完備的系統(tǒng)。
綜上所述,用C語(yǔ)言進(jìn)行單片機(jī)程序設(shè)計(jì)是單片機(jī)開發(fā)與應(yīng)用的必然趨勢(shì)。所以作為一個(gè)技術(shù)全面并涉足較大規(guī)模的軟件系統(tǒng)開發(fā)的單片機(jī)開發(fā)人員最好能夠掌握基本的C語(yǔ)言編程。
4. 當(dāng)開發(fā)一個(gè)較復(fù)雜而又開發(fā)時(shí)間短的項(xiàng)目時(shí),用C還是用匯編開發(fā)好?
對(duì)于復(fù)雜而開發(fā)時(shí)間緊的項(xiàng)目時(shí),可以采用C語(yǔ)言,但前提是要求對(duì)該MCU系統(tǒng)的C語(yǔ)言和C編譯器非常熟悉,特別要注意該C編譯系統(tǒng)所能支持的數(shù)據(jù)類型和算法。雖然C語(yǔ)言是最普遍的一種高級(jí)語(yǔ)言,但不同的MCU廠家其C語(yǔ)言編譯系統(tǒng)是有所差別的,特別是在一些特殊功能模塊的操作上。如果對(duì)這些特性不了解,那調(diào)試起來(lái)就有的煩了,到頭來(lái)可能還不如用匯編來(lái)的快。
5. 在教學(xué)中要用到8088和196芯片單片機(jī)教材,請(qǐng)問(wèn)那里可以找到關(guān)于這方面的書或資料?
有關(guān)這方面的教材,大學(xué)里常用的一本是《IBM-PC 匯編語(yǔ)言程序設(shè)計(jì)》(清華大學(xué)出版社出版),在網(wǎng)上以及書店都是可以找到的,另外網(wǎng)上還可以搜索到很多其他的教材如:《微機(jī)原理及匯編語(yǔ)言教程》(楊延雙 張曉冬等編著 )和《16/32 位微機(jī)原理、匯編語(yǔ)言及接口技術(shù)》(作者:鐘曉捷 陳濤 ,機(jī)械工業(yè)出版社出版)等,可以在較大型的科技書店里查找或者直接從網(wǎng)上訂購(gòu)。
6. 初學(xué)者到底是應(yīng)該先學(xué)C還是匯編?
對(duì)于單片機(jī)的初學(xué)者來(lái)說(shuō),應(yīng)該從匯編學(xué)起。因?yàn)閰R編語(yǔ)言是最接近機(jī)器碼的一種語(yǔ)言,可以加深初學(xué)者對(duì)單片機(jī)各個(gè)功能模塊的了解,從而打好扎實(shí)的基 礎(chǔ)。
7. 在芯片集成技術(shù)日益進(jìn)步的今天,單片機(jī)的集成技術(shù)發(fā)展也很迅速,在傳統(tǒng)的40引腳的基礎(chǔ)上,推出20引腳的單片機(jī)系列,使很多的引腳可以復(fù)用,這種復(fù)用技術(shù)的使用在實(shí)際應(yīng)用中會(huì)不會(huì)影響其功能的執(zhí)行?
在實(shí)際應(yīng)用中不會(huì)影響其功能的執(zhí)行,但是要注意的是, 有的MCU如果采用復(fù)用引腳的話,該引腳會(huì)有一些應(yīng)用上的限制,這在相應(yīng)的datasheet里面都會(huì)有描述,所以在系統(tǒng)規(guī)劃的時(shí)候都要予以注意。
8. Delta-Sigma軟件測(cè)量方式,是什么概念?
Delta-Sigma原理一般應(yīng)用在ADC應(yīng)用中。具體來(lái)說(shuō),Delta-Sigma ADC的工作原理是由差動(dòng)器、積分器和比較器構(gòu)成調(diào)制器,它們一起構(gòu)成一個(gè)反饋環(huán)路。
調(diào)制器以大大高于模擬輸入信號(hào)帶寬的速率運(yùn)行,以便提供過(guò)采樣。模擬輸入與反饋信號(hào)(誤差信號(hào))進(jìn)行差動(dòng) (delta)比較。該比較產(chǎn)生的差動(dòng)輸出饋送到積分器(sigma)中。然后將積分器的輸出饋送到比較器中。比較器的輸出同時(shí)將反饋信號(hào)(誤差信號(hào))傳送到差動(dòng)器,而自身被饋送到數(shù)字濾波器中。這種反饋環(huán)路的目的是使反饋信號(hào)(誤差信號(hào))趨于零。
比較器輸出的結(jié)果就是 1/0 流。該流如果 1 密度較高,則意味著模擬輸入電壓較高;反之,0 密度較高,則意味著模擬輸入電壓較低。接著將 1/0 流饋送到數(shù)字濾波器中,該濾波器通過(guò)過(guò)采樣與抽樣,將 1/0 流從高速率、低精度位流轉(zhuǎn)換成低速率、高精度數(shù)字輸出。
簡(jiǎn)而言之,Delta就是差動(dòng),Sigma就是積分的意思。Delta-Sigma軟件測(cè)試,簡(jiǎn)單理解應(yīng)該是通過(guò)軟件模擬差動(dòng)積分的過(guò)程。具體來(lái)說(shuō),就是偵測(cè)外部輸入的 電壓(或者電流)信號(hào)變化,然后通過(guò)軟件積分運(yùn)算,得出外部信號(hào)隨時(shí)間變化的基本狀況。
-
單片機(jī)
+關(guān)注
關(guān)注
6030文章
44498瀏覽量
632157 -
C語(yǔ)言
+關(guān)注
關(guān)注
180文章
7595瀏覽量
135920 -
調(diào)制器
+關(guān)注
關(guān)注
3文章
829瀏覽量
45082
原文標(biāo)題:?jiǎn)纹瑱C(jī)編程語(yǔ)言及應(yīng)用技巧解析
文章出處:【微信號(hào):mcu168,微信公眾號(hào):硬件攻城獅】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
評(píng)論