資料介紹
對(duì)程序進(jìn)行優(yōu)化,通常是指優(yōu)化程序代碼或程序執(zhí)行速度。優(yōu)化代碼和優(yōu)化速度實(shí)際上是一個(gè)予盾的統(tǒng)一,一般是優(yōu)化了代碼的尺寸,就會(huì)帶來(lái)執(zhí)行時(shí)間的增加,如果優(yōu)化了程序的執(zhí)行速度,通常會(huì)帶來(lái)代碼增加的副作用,很難魚(yú)與熊掌兼得,只能在設(shè)計(jì)時(shí)掌握一個(gè)平衡點(diǎn)。
一、程序結(jié)構(gòu)的優(yōu)化
1、程序的書(shū)寫(xiě)結(jié)構(gòu)
雖然書(shū)寫(xiě)格式并不會(huì)影響生成的代碼質(zhì)量,但是在實(shí)際編寫(xiě)程序時(shí)還是應(yīng)該尊循一定的書(shū)寫(xiě)規(guī)則,一個(gè)書(shū)寫(xiě)清晰、明了的程序,有利于以后的維護(hù)。在書(shū)寫(xiě)程序時(shí),特別是對(duì)于While、for、do…while、if…elst、switch…case等語(yǔ)句或這些語(yǔ)句嵌套組合時(shí),應(yīng)采用“縮格”的書(shū)寫(xiě)形式,
2、標(biāo)識(shí)符
程序中使用的用戶(hù)標(biāo)識(shí)符除要遵循標(biāo)識(shí)符的命名規(guī)則以外,一般不要用代數(shù)符號(hào)(如a、b、x1、y1)作為變量名,應(yīng)選取具有相關(guān)含義的英文單詞(或縮寫(xiě))或漢語(yǔ)拼音作為標(biāo)識(shí)符,以增加程序的可讀性,如:count、number1、red、work等。
3、程序結(jié)構(gòu)
C語(yǔ)言是一種高級(jí)程序設(shè)計(jì)語(yǔ)言,提供了十分完備的規(guī)范化流程控制結(jié)構(gòu)。因此在采用C語(yǔ)言設(shè)計(jì)單片機(jī)應(yīng)用系統(tǒng)程序時(shí),首先要注意盡可能采用結(jié)構(gòu)化的程序設(shè)計(jì)方法,這樣可使整個(gè)應(yīng)用系統(tǒng)程序結(jié)構(gòu)清晰,便于調(diào)試和維護(hù)。于一個(gè)較大的應(yīng)用程序,通常將整個(gè)程序按功能分成若干個(gè)模塊,不同模塊完成不同的功能。各個(gè)模塊可以分別編寫(xiě),甚至還可以由不同的程序員編寫(xiě),一般單個(gè)模塊完成的功能較為簡(jiǎn)單,設(shè)計(jì)和調(diào)試也相對(duì)容易一些。在C語(yǔ)言中,一個(gè)函數(shù)就可以認(rèn)為是一個(gè)模塊。所謂程序模塊化,不僅是要將整個(gè)程序劃分成若干個(gè)功能模塊,更重要的是,還應(yīng)該注意保持各個(gè)模塊之間變量的相對(duì)獨(dú)立性,即保持模塊的獨(dú)立性,盡量少使用全局變量等。對(duì)于一些常用的功能模塊,還可以封裝為一個(gè)應(yīng)用程序庫(kù),以便需要時(shí)可以直接調(diào)用。但是在使用模塊化時(shí),如果將模塊分成太細(xì)太小,又會(huì)導(dǎo)致程序的執(zhí)行效率變低(進(jìn)入和退出一個(gè)函數(shù)時(shí)保護(hù)和恢復(fù)寄存器占用了一些時(shí)間)。
4、定義常數(shù)
在程序化設(shè)計(jì)過(guò)程中,對(duì)于經(jīng)常使用的一些常數(shù),如果將它直接寫(xiě)到程序中去,一旦常數(shù)的數(shù)值發(fā)生變化,就必須逐個(gè)找出程序中所有的常數(shù),并逐一進(jìn)行修改,這樣必然會(huì)降低程序的可維護(hù)性。因此,應(yīng)盡量當(dāng)采用預(yù)處理命令方式來(lái)定義常數(shù),而且還可以避免輸入錯(cuò)誤。
5、減少判斷語(yǔ)句
能夠使用條件編譯(ifdef)的地方就使用條件編譯而不使用if語(yǔ)句,有利于減少編譯生成的代碼的長(zhǎng)度,能夠不用判斷語(yǔ)句則少用判斷用語(yǔ)句。
6、表達(dá)式
對(duì)于一個(gè)表達(dá)式中各種運(yùn)算執(zhí)行的優(yōu)先順序不太明確或容易混淆的地方,應(yīng)當(dāng)采用圓括號(hào)明確指定它們的優(yōu)先順序。一個(gè)表達(dá)式通常不能寫(xiě)得太復(fù)雜,如果表達(dá)式太復(fù)雜,時(shí)間久了以后,自己也不容易看得懂,不利于以后的維護(hù)。
7、函數(shù)
對(duì)于程序中的函數(shù),在使用之前,應(yīng)對(duì)函數(shù)的類(lèi)型進(jìn)行說(shuō)明,對(duì)函數(shù)類(lèi)型的說(shuō)明必須保證它與原來(lái)定義的函數(shù)類(lèi)型一致,對(duì)于沒(méi)有參數(shù)和沒(méi)有返回值類(lèi)型的函數(shù)應(yīng)加上“void”說(shuō)明。如果果需要縮短代碼的長(zhǎng)度,可以將程序中一些公共的程序段定義為函數(shù),在Keil中的高級(jí)別優(yōu)化就是這樣的。如果需要縮短程序的執(zhí)行時(shí)間,在程序調(diào)試結(jié)束后,將部分函數(shù)用宏定義來(lái)代替。注意,應(yīng)該在程序調(diào)試結(jié)束后再定義宏,因?yàn)榇蠖鄶?shù)編譯系統(tǒng)在宏展開(kāi)之后才會(huì)報(bào)錯(cuò),這樣會(huì)增加排錯(cuò)的難度。
8、盡量少用全局變量,多用局部變量。因?yàn)槿肿兞渴欠旁跀?shù)據(jù)存儲(chǔ)器中,定義一個(gè)全局變量,MCU就少一個(gè)可以利用的數(shù)據(jù)存儲(chǔ)器空間,如果定義了太多的全局變量,會(huì)導(dǎo)致編譯器無(wú)足夠的內(nèi)存可以分配。而局部變量大多定位于MCU內(nèi)部的寄存器中,在絕大多數(shù)MCU中,使用寄存器操作速度比數(shù)據(jù)存儲(chǔ)器快,指令也更多更靈活,有利于生成質(zhì)量更高的代碼,而且局部變量所的占用的寄存器和數(shù)據(jù)存儲(chǔ)器在不同的模塊中可以重復(fù)利用。
9、設(shè)定合適的編譯程序選項(xiàng)
許多編譯程序有幾種不同的優(yōu)化選項(xiàng),在使用前應(yīng)理解各優(yōu)化選項(xiàng)的含義,然后選用最合適的一種優(yōu)化方式。通常情況下一旦選用最高級(jí)優(yōu)化,編譯程序會(huì)近乎病態(tài)地追求代碼優(yōu)化,可能會(huì)影響程序的正確性,導(dǎo)致程序運(yùn)行出錯(cuò)。因此應(yīng)熟悉所使用的編譯器,應(yīng)知道哪些參數(shù)在優(yōu)化時(shí)會(huì)受到影響,哪些參數(shù)不會(huì)受到影響。在ICCAVR中,有“Default”和“Enable Code Compression”兩個(gè)優(yōu)化選項(xiàng)。在CodeVisionAVR中,“Tiny”和“small”兩種內(nèi)存模式。在IAR中,共有7種不同的內(nèi)存模式選項(xiàng)。在GCCAVR中優(yōu)化選項(xiàng)更多,一不小心更容易選到不恰當(dāng)?shù)倪x項(xiàng)。
二、代碼的優(yōu)化
1、選擇合適的算法和數(shù)據(jù)結(jié)構(gòu)
應(yīng)該熟悉算法語(yǔ)言,知道各種算法的優(yōu)缺點(diǎn),具體資料請(qǐng)參見(jiàn)相應(yīng)的參考資料,有很多計(jì)算機(jī)書(shū)籍上都有介紹。將比較慢的順序查找法用較快的二分查找或亂序查找法代替,插入排序或冒泡排序法用快速排序、合并排序或根排序代替,都可以大大提高程序執(zhí)行的效率。。選擇一種合適的數(shù)據(jù)結(jié)構(gòu)也很重要,比如你在一堆隨機(jī)存放的數(shù)中使用了大量的插入和刪除指令,那使用鏈表要快得多。數(shù)組與指針語(yǔ)句具有十分密碼的關(guān)系,一般來(lái)說(shuō),指針比較靈活簡(jiǎn)潔,而數(shù)組則比較直觀,容易理解。對(duì)于大部分的編譯器,使用指針比使用數(shù)組生成的代碼更短,執(zhí)行效率更高。但是在Keil中則相反,使用數(shù)組比使用的指針生成的代碼更短。
3、使用盡量小的數(shù)據(jù)類(lèi)型
能夠使用字符型(char)定義的變量,就不要使用整型(int)變量來(lái)定義;能夠使用整型變量定義的變量就不要用長(zhǎng)整型(long int),能不使用浮點(diǎn)型(float)變量就不要使用浮點(diǎn)型變量。當(dāng)然,在定義變量后不要超過(guò)變量的作用范圍,如果超過(guò)變量的范圍賦值,C編譯器并不報(bào)錯(cuò),但程序運(yùn)行結(jié)果卻錯(cuò)了,而且這樣的錯(cuò)誤很難發(fā)現(xiàn)。在ICCAVR中,可以在Options中設(shè)定使用printf參數(shù),盡量使用基本型參數(shù)(%c、%d、%x、%X、%u和%s格式說(shuō)明符),少用長(zhǎng)整型參數(shù)(%ld、%lu、%lx和%lX格式說(shuō)明符),至于浮點(diǎn)型的參數(shù)(%f)則盡量不要使用,其它C編譯器也一樣。在其它條件不變的情況下,使用%f參數(shù),會(huì)使生成的代碼的數(shù)量增加很多,執(zhí)行速度降低。
4、使用自加、自減指令
通常使用自加、自減指令和復(fù)合賦值表達(dá)式(如a-=1及a+=1等)都能夠生成高質(zhì)量的程序代碼,編譯器通常都能夠生成inc和dec之類(lèi)的指令,而使用a=a+1或a=a-1之類(lèi)的指令,有很多C編譯器都會(huì)生成二到三個(gè)字節(jié)的指令。在AVR單片適用的ICCAVR、GCCAVR、IAR等C編譯器以上幾種書(shū)寫(xiě)方式生成的代碼是一樣的,也能夠生成高質(zhì)量的inc和dec之類(lèi)的的代碼。
- 高質(zhì)量程序設(shè)計(jì)指南之C++C語(yǔ)言 0次下載
- C語(yǔ)言程序設(shè)計(jì)第四講結(jié)構(gòu)化程序設(shè)計(jì)之選擇 0次下載
- C#語(yǔ)言程序設(shè)計(jì)實(shí)用教程 51次下載
- 使用51單片機(jī)進(jìn)行PS2鍵盤(pán)解碼實(shí)驗(yàn)的C語(yǔ)言程序免費(fèi)下載
- 使用51單片機(jī)進(jìn)行按鍵掃描的C語(yǔ)言程序免費(fèi)下載
- 如何進(jìn)行單片機(jī)C程序代碼的優(yōu)化
- 使用51單片機(jī)進(jìn)行12864液晶時(shí)鐘的C語(yǔ)言程序免費(fèi)下載
- 使用C語(yǔ)言進(jìn)行IOT物聯(lián)網(wǎng)編程的程序免費(fèi)下載 10次下載
- 如何使用單片機(jī)設(shè)計(jì)音樂(lè)盒進(jìn)行播放小蘋(píng)果的C語(yǔ)言程序免費(fèi)下載 21次下載
- 使用單片機(jī)進(jìn)行紅外遙控的C語(yǔ)言程序資料免費(fèi)下載 19次下載
- 單片機(jī)C語(yǔ)言中如何使用nop函數(shù)進(jìn)行短延時(shí)的效果資料和程序說(shuō)明 10次下載
- C語(yǔ)言教程之如何進(jìn)行最簡(jiǎn)單的C程序設(shè)計(jì)實(shí)現(xiàn)程序說(shuō)明 2次下載
- 單片機(jī)進(jìn)行AD轉(zhuǎn)換的C語(yǔ)言程序資料免費(fèi)下載 17次下載
- DSP的C語(yǔ)言編程的詳細(xì)簡(jiǎn)介和優(yōu)化改進(jìn)設(shè)計(jì)的詳細(xì)概述 8次下載
- 關(guān)于c語(yǔ)言編寫(xiě)的算法程序 12次下載
- 深入理解C語(yǔ)言:循環(huán)語(yǔ)句的應(yīng)用與優(yōu)化技巧 214次閱讀
- AWTK-WEB 快速入門(mén)(1) - C 語(yǔ)言應(yīng)用程序 257次閱讀
- 技術(shù)干貨驛站 ▏深入理解C語(yǔ)言:掌握程序結(jié)構(gòu)知識(shí) 1484次閱讀
- 怎么寫(xiě)出效率高、思路清晰的C語(yǔ)言程序? 604次閱讀
- 用C語(yǔ)言構(gòu)建高效的嵌入式程序 647次閱讀
- 如何把C++程序改寫(xiě)成C語(yǔ)言 3392次閱讀
- C語(yǔ)言中條件編譯詳解 3131次閱讀
- 為什么說(shuō)C語(yǔ)言程序運(yùn)行時(shí)要比其他語(yǔ)言編寫(xiě)的程序快得多 2252次閱讀
- 單片機(jī)液晶漢字顯示的C語(yǔ)言程序 5130次閱讀
- DS18B20的C語(yǔ)言驅(qū)動(dòng)程序 5522次閱讀
- C語(yǔ)言的簡(jiǎn)介和特點(diǎn)說(shuō)明 8053次閱讀
- 如何寫(xiě)好一個(gè)效率高效思路清晰的C語(yǔ)言程序教你關(guān)鍵的三招 5432次閱讀
- 用C語(yǔ)言進(jìn)行程序構(gòu)架構(gòu)建的“三板斧” 4085次閱讀
- 一文詳解單片機(jī)C程序及代碼的優(yōu)化 4870次閱讀
- 小波去噪c語(yǔ)言程序 1.4w次閱讀
下載排行
本周
- 1電子電路原理第七版PDF電子教材免費(fèi)下載
- 0.00 MB | 1490次下載 | 免費(fèi)
- 2單片機(jī)典型實(shí)例介紹
- 18.19 MB | 92次下載 | 1 積分
- 3S7-200PLC編程實(shí)例詳細(xì)資料
- 1.17 MB | 27次下載 | 1 積分
- 4筆記本電腦主板的元件識(shí)別和講解說(shuō)明
- 4.28 MB | 18次下載 | 4 積分
- 5開(kāi)關(guān)電源原理及各功能電路詳解
- 0.38 MB | 10次下載 | 免費(fèi)
- 6基于AT89C2051/4051單片機(jī)編程器的實(shí)驗(yàn)
- 0.11 MB | 4次下載 | 免費(fèi)
- 7藍(lán)牙設(shè)備在嵌入式領(lǐng)域的廣泛應(yīng)用
- 0.63 MB | 3次下載 | 免費(fèi)
- 89天練會(huì)電子電路識(shí)圖
- 5.91 MB | 3次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 2PADS 9.0 2009最新版 -下載
- 0.00 MB | 66304次下載 | 免費(fèi)
- 3protel99下載protel99軟件下載(中文版)
- 0.00 MB | 51209次下載 | 免費(fèi)
- 4LabView 8.0 專(zhuān)業(yè)版下載 (3CD完整版)
- 0.00 MB | 51043次下載 | 免費(fèi)
- 5555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33562次下載 | 免費(fèi)
- 6接口電路圖大全
- 未知 | 30320次下載 | 免費(fèi)
- 7Multisim 10下載Multisim 10 中文版
- 0.00 MB | 28588次下載 | 免費(fèi)
- 8開(kāi)關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21539次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935053次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537791次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234313次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233045次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191183次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183277次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138039次下載 | 免費(fèi)
評(píng)論
查看更多