女人被狂躁到高潮视频免费无遮挡,内射人妻骚骚骚,免费人成小说在线观看网站,九九影院午夜理论片少妇,免费av永久免费网址

當(dāng)前位置:首頁(yè) > 嵌入式 > 嵌入式教程
[導(dǎo)讀]淺析嵌入式程序設(shè)計(jì)中的優(yōu)化問(wèn)題

    嵌入式系統(tǒng)由于受功耗、成本和體積等因素的制約,嵌入式微處理器的處理能力與桌面系統(tǒng)處理器相比也存在較大差距,故嵌入式系統(tǒng)對(duì)程序運(yùn)行的空間和時(shí)間要求更為苛刻。通常,需要對(duì)嵌入式應(yīng)用程序進(jìn)行性能優(yōu)化,以滿(mǎn)足嵌入式應(yīng)用的性能需求。

1 嵌入式程序優(yōu)化的類(lèi)型
   
嵌入式應(yīng)用程序優(yōu)化,指在不改變程序功能的情況下,通過(guò)修改原來(lái)程序的算法、結(jié)構(gòu),并利用軟件開(kāi)發(fā)工具對(duì)程序進(jìn)行改進(jìn),使修改后的程序運(yùn)行速度更高或代碼尺寸更小。

    按照優(yōu)化的側(cè)重點(diǎn)不同,程序優(yōu)化可分為運(yùn)行速度優(yōu)化和代碼尺寸優(yōu)化。運(yùn)行速度優(yōu)化是指在充分掌握軟硬件特性的基礎(chǔ)上,通過(guò)應(yīng)用程序結(jié)構(gòu)調(diào)整等手段來(lái)縮短完成指定任務(wù)所需的運(yùn)行時(shí)間;代碼尺寸優(yōu)化則是指應(yīng)用程序在能夠正確實(shí)現(xiàn)所需功能的前提下,盡可能減小程序的代碼量。實(shí)際應(yīng)用中,這兩者往往是相互矛盾的,為了提高程序運(yùn)行速度,就要以增加代碼量為代價(jià);而為了減小程序代碼尺寸,可能又要以降低程序運(yùn)行速度為代價(jià)。因此,在對(duì)程序進(jìn)行優(yōu)化之前,應(yīng)根據(jù)實(shí)際需要來(lái)制定具體的優(yōu)化策略。隨著計(jì)算機(jī)和微電子技術(shù)的不斷發(fā)展,存儲(chǔ)空間已不再是制約嵌入式系統(tǒng)的主要因素,因此本文主要討論運(yùn)行速度優(yōu)化。

2 嵌入式程序優(yōu)化遵循的原則
   
嵌入式程序優(yōu)化主要遵循以下3個(gè)原則。
    ①等效原則:優(yōu)化前后程序?qū)崿F(xiàn)的功能一致。
    ②有效原則:優(yōu)化后要比優(yōu)化前運(yùn)行速度快或占用存儲(chǔ)空間小,或二者兼有。
    ③經(jīng)濟(jì)原則:優(yōu)化程序要付出較小的代價(jià),取得較好的結(jié)果。

3 嵌入式程序優(yōu)化的主要方面
   
嵌入式程序的優(yōu)化分為3個(gè)方面:算法和數(shù)據(jù)結(jié)構(gòu)優(yōu)化、編譯優(yōu)化以及代碼優(yōu)化。

3.1 算法和數(shù)據(jù)結(jié)構(gòu)優(yōu)化

    算法和數(shù)據(jù)結(jié)構(gòu)是程序設(shè)計(jì)的核心所在,算法的好壞在很大程度上決定了程序的優(yōu)劣。為了實(shí)現(xiàn)某種功能,通??梢圆捎枚喾N算法,不同算法的復(fù)雜度和效率差別很大。選擇一種高效的算法或?qū)λ惴ㄟM(jìn)行優(yōu)化,可以使應(yīng)用程序獲得更高的優(yōu)化性能。例如:在數(shù)據(jù)搜索時(shí),二分查找法要比順序查找法快。遞歸程序需要大量的過(guò)程調(diào)用,并在堆棧中保存所有返回過(guò)程的局部變量,時(shí)間效率和空間效率都非常低;若根據(jù)實(shí)際情況對(duì)遞歸程序采用迭代、堆棧等方法進(jìn)行非遞歸轉(zhuǎn)換,則可大幅度提高程序的性能。

    數(shù)據(jù)結(jié)構(gòu)在程序的設(shè)計(jì)中也占有重要的地位。例如:如果在一些無(wú)序的數(shù)據(jù)中多次進(jìn)行插入、刪除數(shù)據(jù)項(xiàng)操作,那么采用鏈表結(jié)構(gòu)就會(huì)比較快。

    算法和數(shù)據(jù)結(jié)構(gòu)優(yōu)化是首選的優(yōu)化技術(shù)。

3.2 編譯優(yōu)化
   
現(xiàn)在,很多的編譯器都具有一定的代碼優(yōu)化功能。在編譯時(shí),借用并行程序設(shè)計(jì)技術(shù),進(jìn)行相關(guān)性分析;獲得源程序的語(yǔ)義信息,采用軟件流水線、數(shù)據(jù)規(guī)劃、循環(huán)重構(gòu)等技術(shù),自動(dòng)進(jìn)行一些與處理器體系無(wú)關(guān)的優(yōu)化,生成高質(zhì)量的代碼。許多編譯器有不同級(jí)別的優(yōu)化選項(xiàng),可以選用一種合適的優(yōu)化方式。通常情況下,如果選用了最高級(jí)別的優(yōu)化方式,那么編譯器將片面追求代碼的優(yōu)化,有時(shí)會(huì)導(dǎo)致錯(cuò)誤。

    另外,還有一些專(zhuān)用的編譯器針對(duì)某些體系結(jié)構(gòu)進(jìn)行了優(yōu)化設(shè)計(jì),可以充分利用硬件資源來(lái)生成高質(zhì)量的代碼。例如:Microsoft eMbedded Visual C++版的Intel編譯器完全針對(duì)Intel XScale體系,經(jīng)過(guò)高度優(yōu)化,能創(chuàng)建運(yùn)行速度更快的代碼。此編譯器采用了多種優(yōu)化技術(shù),包括優(yōu)化指令管道操作的調(diào)度技術(shù)、雙重加載與存儲(chǔ)Intel XScale技術(shù)功能支持以及過(guò)程間優(yōu)化(將函數(shù)使用的變量存放到寄存器,以便快速訪問(wèn))等。

    在嵌入式軟件開(kāi)發(fā)過(guò)程中應(yīng)選擇一種優(yōu)化能力強(qiáng)的編譯器,充分利用其代碼優(yōu)化功能,生成高效的代碼,提高程序的運(yùn)行效率。

3.3 代碼優(yōu)化
   
代碼優(yōu)化,就是采用匯編語(yǔ)言或更精簡(jiǎn)的程序代碼來(lái)代替原有的代碼,使編譯后的程序運(yùn)行效率更高。編譯器可以自動(dòng)完成程序段和代碼塊范圍內(nèi)的優(yōu)化,但很難獲取程序語(yǔ)義信息、算法流程和程序運(yùn)行狀態(tài)信息,因而需要編程人員進(jìn)行手工優(yōu)化。以下是一些常用的優(yōu)化技術(shù)和技巧。

(1)代碼替換

    使用周期短的指令代替周期長(zhǎng)的指令,以降低運(yùn)算的強(qiáng)度。
    ①減少除法運(yùn)算。用關(guān)系運(yùn)算符兩邊乘除數(shù)避免除法操作,還有一些除法和取模的運(yùn)算可以用位操作來(lái)代替。因?yàn)槲徊僮髦噶钪恍枰粋€(gè)指令周期,而“/”運(yùn)算則需要調(diào)用子程序,代碼長(zhǎng),執(zhí)行慢。例如:
    優(yōu)化前if((a/b)>c)和a=a/4
    優(yōu)化后if(a>(b*c))和a=a>>2
    ②減少乘方運(yùn)算。例如:
    優(yōu)化前a=pow(a,3.0)
    優(yōu)化后a=a*a*a
    ③使用白加、自減指令。例如:
    優(yōu)化前a=a+1、a=a-l
    優(yōu)化后a++、a--或inc、dec
    ④盡量使用小的數(shù)據(jù)類(lèi)型。在所定義的變量滿(mǎn)足使用要求的條件下,優(yōu)先使用順序?yàn)椋鹤址?char)>整型(im)>長(zhǎng)整型(long int)>浮點(diǎn)型(float)。
    對(duì)除法來(lái)說(shuō),使用無(wú)符號(hào)數(shù)比有符號(hào)數(shù)會(huì)有更高的效率。在實(shí)際調(diào)用中,盡量減少數(shù)據(jù)類(lèi)型的強(qiáng)制轉(zhuǎn)換;少用浮點(diǎn)運(yùn)算,如果運(yùn)算的結(jié)果能夠控制在誤差之內(nèi),則可用長(zhǎng)整型代替浮點(diǎn)型。

(2)全局變量與局部變量

    少用全局變量,多用局部變量。全局變量是放在數(shù)據(jù)存儲(chǔ)器中的,定義了全局變量,MCU就少了一個(gè)可以利用的數(shù)據(jù)存儲(chǔ)器空間,太多的全局變量,會(huì)導(dǎo)致編譯器無(wú)足夠的內(nèi)存分配;而局部變量則大多定位于MCU內(nèi)部的寄存器中。在絕大多數(shù)的MCU中,使用寄存器的操作速度比數(shù)據(jù)存儲(chǔ)器快,指令也更靈活,有利于生成質(zhì)量更高的代碼,而且局部變量所占用的寄存器和數(shù)據(jù)存儲(chǔ)器在不同的模塊中可以重復(fù)利用。

(3)使用寄存器變量

    當(dāng)一個(gè)變量被頻繁讀/寫(xiě)時(shí),需要反復(fù)訪問(wèn)內(nèi)存,花費(fèi)大量的存取時(shí)間。為了提高訪問(wèn)效率,可以使用CPU寄存器變量,不需要訪問(wèn)內(nèi)存,直接進(jìn)行讀/寫(xiě)。循環(huán)次數(shù)較多的循環(huán)控制變量及循環(huán)體內(nèi)反復(fù)使用的變量均可定義為寄存器變量,而循環(huán)計(jì)數(shù)是應(yīng)用寄存器變量的最佳選擇。只有局部自動(dòng)變量和形參才可以定義為寄存器變量。因?yàn)榧拇嫫髯兞繉儆趧?dòng)態(tài)存儲(chǔ)方式,因此凡需要采用靜態(tài)存儲(chǔ)方式的變量都不能定義為寄存器變量。寄存器變量的說(shuō)明符是register。下面是一個(gè)采用寄存器變量的例子:

   
(4)減少或避免執(zhí)行耗時(shí)的操作
    應(yīng)用程序的大量運(yùn)行時(shí)問(wèn)通?;ㄙM(fèi)在關(guān)鍵程序模塊,關(guān)鍵模塊往往包含循環(huán)或嵌套循環(huán)。減少循環(huán)中耗時(shí)的操作,可以提高程序的執(zhí)行速度。常見(jiàn)的耗時(shí)操作有:輸入/輸出操作、文件訪問(wèn)、圖形界面操作和系統(tǒng)調(diào)用等。其中,如果無(wú)法避免文件的讀/寫(xiě),那么對(duì)文件的訪問(wèn)將是影響程序運(yùn)行速度的一大因素。提高文件訪問(wèn)速度的方法有兩種:一種是采用內(nèi)存映射文件;另一種是使用內(nèi)存緩存。

(5)switch語(yǔ)句用法的優(yōu)化

    編程時(shí),對(duì)case值按照可能性排序,將最可能發(fā)生的情況放在第一個(gè),最不可能的情況放在最后一個(gè),可以提高switch語(yǔ)句塊的執(zhí)行速度。

(6)循環(huán)體的優(yōu)化

    循環(huán)體是程序設(shè)計(jì)和優(yōu)化的重點(diǎn),對(duì)于一些不需要循環(huán)變量參加運(yùn)算的模塊,可以把它放到循環(huán)的外面。對(duì)于次數(shù)固定的循環(huán)體,for循環(huán)比while循環(huán)效率更高,減計(jì)數(shù)循環(huán)比增計(jì)數(shù)循環(huán)速度快。例如:

   
    實(shí)際運(yùn)行時(shí),每次循環(huán)需要在循環(huán)體外加兩條指令:一條減法指令(減少循環(huán)計(jì)數(shù)值)和一條條件分支指令。這些指令稱(chēng)為“循環(huán)開(kāi)銷(xiāo)”。在ARM處理器上,減法指令需要1個(gè)周期,條件分支指令需要3個(gè)周期,這樣每個(gè)循環(huán)另加了4個(gè)周期的開(kāi)銷(xiāo)。可以采用循環(huán)展開(kāi)的方法來(lái)提高循環(huán)運(yùn)行的速度,即:重復(fù)循環(huán)主題多次,并按同樣的比例減少循環(huán)次數(shù)來(lái)減小循環(huán)的開(kāi)銷(xiāo),以增加代碼尺寸。來(lái)?yè)Q取程序的運(yùn)行速度。。

(7)函數(shù)調(diào)用

    高效的調(diào)用函數(shù),盡量限制使用函數(shù)的參數(shù)個(gè)數(shù),不要超過(guò)4個(gè)。ARM調(diào)用時(shí),4個(gè)以下的形參通過(guò)寄存器傳遞,第5個(gè)以上的形參通過(guò)存儲(chǔ)器棧傳遞。如果有更多的參數(shù)調(diào)用,則可將相關(guān)的參數(shù)組織在一個(gè)結(jié)構(gòu)體內(nèi),用傳遞結(jié)構(gòu)體指針來(lái)代替參數(shù)。

(8)內(nèi)聯(lián)函數(shù)和內(nèi)嵌匯編

    對(duì)性能影響大的重要函數(shù)可以使用關(guān)鍵字_inline內(nèi)聯(lián),會(huì)省去調(diào)用函數(shù)的開(kāi)銷(xiāo),負(fù)面影響是增加了代碼尺寸。程序中對(duì)時(shí)間要求苛刻的部分可以用內(nèi)嵌匯編來(lái)編寫(xiě),通??梢詭?lái)速度上的顯著提高。

(9)查表代替計(jì)算

    在程序中盡量不進(jìn)行非常復(fù)雜的運(yùn)算,如浮點(diǎn)數(shù)的開(kāi)方。對(duì)于這些消耗時(shí)間和資源的運(yùn)算,可以采用空間換取時(shí)間的方法。預(yù)先將函數(shù)值計(jì)算出來(lái),置于程序存儲(chǔ)區(qū)中,以后程序運(yùn)行時(shí)直接查表即可,減小了程序執(zhí)行過(guò)程中重復(fù)計(jì)算的工作量。

(10)使用針對(duì)硬件優(yōu)化的函數(shù)庫(kù)

    Intel公司為XScale處理器設(shè)計(jì)的GPP(Graphics Performance Primitives library)/IPP(Integrated Perform-ance Primitives library)庫(kù),針對(duì)多媒體處理、圖形處理和數(shù)值運(yùn)算的一些典型操作和算法進(jìn)行了手工優(yōu)化,可以很好地發(fā)揮XScale硬件的計(jì)算潛能,達(dá)到很高的執(zhí)行效率。

(11)利用硬件特性

    為了提高程序的運(yùn)行效率,要充分利用硬件特性來(lái)減小其運(yùn)行開(kāi)銷(xiāo),例如減少中斷次數(shù)、利用DMA傳輸方式等。

    CPU對(duì)各種存儲(chǔ)器的訪問(wèn)速度排序依次為:CPU內(nèi)部RAM>外部同步RAM>外部異步RAM>Flash/ROM。對(duì)于已經(jīng)燒錄在Flash或ROM中的程序代碼,如果讓CPU直接從中讀取代碼執(zhí)行,運(yùn)行速度較慢,則可在系統(tǒng)啟動(dòng)后將Flash或ROM中的目標(biāo)代碼拷貝至RAM中后執(zhí)行,以提高程序的運(yùn)行速度。

4 結(jié)論
   
嵌入式程序的性能優(yōu)化與軟件的開(kāi)發(fā)周期、開(kāi)發(fā)成本、軟件的可讀性之聞通常存在矛盾。要權(quán)衡利弊,作出折中的選擇。將算法和數(shù)據(jù)結(jié)構(gòu)優(yōu)化作為首選優(yōu)化技術(shù);然后根據(jù)功能、性能差異和投資預(yù)算等因素選擇高效的編譯器、系統(tǒng)運(yùn)行庫(kù)和圖形庫(kù);使用性能監(jiān)測(cè)工具偵測(cè)占主要運(yùn)行時(shí)間的程序熱點(diǎn),采用代碼優(yōu)化手段對(duì)其進(jìn)行優(yōu)化;最后使用高效的編譯器進(jìn)行編譯優(yōu)化,從而得到高質(zhì)量的代碼。

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

經(jīng)過(guò)幾十年發(fā)展,嵌入式技術(shù)已經(jīng)用在了我們生活中的方方面面,但是嵌入式始終都帶有小眾,專(zhuān)業(yè)性強(qiáng)的屬性,讓很多非嵌入式領(lǐng)域的同學(xué)望而卻步。近十幾年的發(fā)展,物聯(lián)網(wǎng)覆蓋了越來(lái)越多領(lǐng)域,包括了家居,商業(yè),工業(yè),農(nóng)業(yè)等領(lǐng)域,不僅吸引...

關(guān)鍵字: 嵌入式 物聯(lián)網(wǎng) 技術(shù)

隨著IT技術(shù)飛速發(fā)展,互聯(lián)網(wǎng)已經(jīng)進(jìn)入了“物聯(lián)網(wǎng)”時(shí)代。物聯(lián)網(wǎng)中需要的大量設(shè)備不在依賴(lài)人與人之間的交互產(chǎn)生聯(lián)系,更多通過(guò)協(xié)議、通信、程序設(shè)計(jì)等方式連接到一處。即 “物聯(lián)網(wǎng)”的目的則是讓所有的物品都具有計(jì)算機(jī)的智能但并不以通...

關(guān)鍵字: 嵌入式 物聯(lián)網(wǎng) 計(jì)算機(jī)

要問(wèn)機(jī)器人公司哪家強(qiáng),波士頓動(dòng)力絕對(duì)是其中的佼佼者。近來(lái)年該公司在機(jī)器人研發(fā)方面獲得的一些成果令人印象深刻,比如其開(kāi)發(fā)的機(jī)器人會(huì)后空翻,自主爬樓梯等。這不,波士頓動(dòng)力又發(fā)布了其機(jī)器人組團(tuán)跳男團(tuán)舞的新視頻,表演的機(jī)器人包括...

關(guān)鍵字: 機(jī)器人 BSP 工業(yè)機(jī)器人 現(xiàn)代汽車(chē)

南京2022年10月17日 /美通社/ -- 日前《2022第三屆中國(guó)高端家電品牌G50峰會(huì)》于浙江寧波落幕,來(lái)自?xún)砂儆嗝袠I(yè)大咖、專(zhuān)家學(xué)者共同探討了在形勢(shì)依然嚴(yán)峻的當(dāng)下,如何以科技創(chuàng)新、高端化轉(zhuǎn)型等手段,幫助...

關(guān)鍵字: LINK AI BSP 智能家電

SAIHUB CAB 025M成功獲得安全試驗(yàn)所UL美國(guó)與加拿大認(rèn)證證書(shū) 新加坡2022年10月17日 /美通社/ -- SAI.TECH Global Corporation("SAI.TECH"...

關(guān)鍵字: AI BSP PS 清潔能源

鄭州2022年10月17日 /美通社/ -- 近日,《福布斯》發(fā)布了"2022年全球最佳雇主榜單"(The World's Best Employers 2022),中國(guó)平安再度上榜并排名全...

關(guān)鍵字: 福布斯 ST TI BSP

通過(guò)第二項(xiàng)3nm設(shè)計(jì)選用擴(kuò)展技術(shù)領(lǐng)先地位 第三季度強(qiáng)勁的貿(mào)易和設(shè)計(jì)選用反映出我們結(jié)合了IP和定制硅的混合業(yè)務(wù)模式 自2022年9月1日起,OpenFive首次并入集團(tuán) 盡管宏觀環(huán)境困難,但管理層仍對(duì)業(yè)務(wù)...

關(guān)鍵字: BSP ALPHA PEN Silicon

歐洲藥品管理局人用藥品管理委員會(huì) (CHMP) 的積極建議是基于 EFFISAYIL® 1 研究結(jié)果,該研究是針對(duì)泛發(fā)性膿皰型銀屑病 (GPP) 發(fā)作患者的最大的臨床研究[1] 與斑塊狀銀屑病不同,GP...

關(guān)鍵字: HM BSP GP FOR

流體動(dòng)壓滑動(dòng)軸承為風(fēng)機(jī)發(fā)展書(shū)寫(xiě)嶄新篇章 軸承滑動(dòng)層增材制造與精加工為工業(yè)級(jí)大規(guī)模生產(chǎn)鋪平道路 軸承設(shè)計(jì)從綜合性系統(tǒng)理念出發(fā) 德國(guó)施韋因富特和漢堡2022年10月17日 /美通社/ -- 舍弗勒推出了采...

關(guān)鍵字: 齒輪箱 滑動(dòng)軸承 風(fēng)力渦輪機(jī) BSP

上海2022年10月17日 /美通社/ -- Brother內(nèi)置墨倉(cāng)彩色噴墨一體機(jī)DCP-C421W新上市。此次Brother創(chuàng)新引入"按需打印,按頁(yè)付費(fèi)"...

關(guān)鍵字: DC 打印機(jī) BSP DESIGN

嵌入式教程

6897 篇文章

關(guān)注

發(fā)布文章

編輯精選

技術(shù)子站

關(guān)閉