《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 解決方案 > ARM首席工程師:關(guān)于Android NDK的10個技巧

ARM首席工程師:關(guān)于Android NDK的10個技巧

2011-08-05
作者:Dave,,ARM首席工程師

    隨著Android NDK(本機(jī)開發(fā)套件)披露了許多的新設(shè)備和新功能,,現(xiàn)在我們可以充分利用這些ARM設(shè)備了,。下面列舉了一些快速提示,,希望對您有所幫助。

 
1 - 關(guān)注目標(biāo)
 
最新的設(shè)備一般是ARMv7,,這意味著它可以使用v7版本和功能,。最新版的NDK增加了ARMv7和NEON代碼支持,可以實(shí)現(xiàn)關(guān)鍵循環(huán)操作和媒體操作優(yōu)化,,遠(yuǎn)超其它方法,。NDK提供小型靜態(tài)庫,可以幫助您識別運(yùn)行時的選項,。有關(guān)如何使用這些功能的示例,,請參見NDK樣本目錄中的hello-neon示例項目。
 
v6是較舊的設(shè)備,,但是NDK未提供專門支持,,您需要自己選擇是安全地構(gòu)建v5TE還是冒險嘗試可能是v5TE的設(shè)備。如果您對速度無甚要求,,并清楚目標(biāo)硬件是什么,則可以嘗試構(gòu)建v6,。盡管無法避免狂熱愛好者將新版的OS裝入舊硬件上,,但事實(shí)是支持Android 2.0及以上版本的最新設(shè)備通常是基于ARMv7的。如果有選擇的話,,最好專注于采用NEON實(shí)施方案的ARMv7,。
 
2 - 不要倉促優(yōu)化
 
除非您計劃移植現(xiàn)有的C++應(yīng)用程序,,否則不要倉促編譯本機(jī)代碼。首先確保應(yīng)用程序正確運(yùn)行并仔細(xì)地profiling配置,。成為瓶頸的要素通常是您意想不到的,。近期的手持設(shè)備都具有兩級緩存,有時還有用于節(jié)省電量的時鐘調(diào)度,,再加上Google為了提高OS性能而付出的長期努力,,我們將會看到更多驚喜。
 
3 - 優(yōu)化,,悄無聲息
 
不留痕跡,。為了得到額外的運(yùn)行周期會誘使您打破設(shè)計,但如非特殊情況,,應(yīng)避免這樣,。執(zhí)行優(yōu)化時,輕輕進(jìn)入,,迅速將應(yīng)用程序關(guān)鍵部分轉(zhuǎn)為本機(jī)或匯編代碼,,然后不留痕跡地退出。這樣,,您不用犧牲可維護(hù)性和調(diào)試便利性,。當(dāng)然,如果您確定重新設(shè)計可以帶來足夠的速度且值得付出代價,,則可放手大干,。
 
4 - 圍繞優(yōu)化實(shí)施重構(gòu)
 
設(shè)計完成后,務(wù)必重新排列代碼以使其更加適于優(yōu)化,,但一旦本機(jī)代碼開始工作,,則要避免修補(bǔ)過度。Java代碼更易重新排列和調(diào)試,。通常應(yīng)先在Java層面優(yōu)化,,以便讓邏輯塊接受本機(jī)代碼。在移植本機(jī)代碼時,,在Java層面改變算法或數(shù)據(jù)結(jié)構(gòu)更具優(yōu)勢且更易處理,。
 
5 - 維護(hù)Java的異常處理
 
執(zhí)行不支持的本機(jī)代碼是個糟糕的主意;即使理想狀態(tài)下,,它也可能造成應(yīng)用程序意外退出,。開發(fā)人員可以大膽推測本機(jī)代碼是否與運(yùn)行程序的設(shè)備兼容,只要有Java實(shí)施方案,,您可以隨時退回Java,。這就是技巧4中優(yōu)化Java版本的好處所在。
 
6 - 小心的分配內(nèi)存
 
不論何時,,在Java中盡可能用Java來分配,,而不要拖延到以后調(diào)用C函數(shù)來解圍,。這樣才能最大程度地減少泄漏并使Java代碼保持簡潔。如果有長期操作,,則應(yīng)在本地分配暫存空間,,但請注意您的指針 - 編寫大量Java代碼時,圍繞指針準(zhǔn)則的舊C語言習(xí)慣可能會忘得很快,。
 
7 - 謹(jǐn)慎采用多線程
 
已經(jīng)有好幾個采用多ARM內(nèi)核的開發(fā)平臺,,客戶使用它們的速度可能比您想像的更快。這樣的想法會誘使您將所有任務(wù)都分割為多線程,??偟膩碚f這是個好主意,但切記,,加重系統(tǒng)負(fù)載盡管能提升速度,,也會犧牲用戶體驗。當(dāng)然,,巧妙使用線程非常地有效,。Android系統(tǒng)自身會創(chuàng)建幾條線程去運(yùn)行一個應(yīng)用程序,然而它們一般都在等待事件,,所以如果您自己創(chuàng)建太多活動執(zhí)行線程,,可能會削弱它們的運(yùn)行能力,適得其反地降低整體用戶體驗,。
 
8 - Java層的線程
 
如果將邏輯分為多個線程,,應(yīng)盡可能通過Java執(zhí)行,而不要采用Pthreads,。使用Java VM管理訪問可以降低風(fēng)險,,且有更多的語言層工具。如果您擔(dān)心設(shè)置成本,,采用現(xiàn)有的小型工人池應(yīng)該不會太困難,。切記將長期任務(wù)的更新發(fā)回到主UI線程,以確保用戶知悉,。另外請牢記一條重要的Android NDK規(guī)則:不要在UI線程上運(yùn)行本機(jī)代碼,。事實(shí)上,最好不在UI線程上運(yùn)行任何Java代碼,;Android有相應(yīng)的API(請查看Handler類)可在非UI線程上經(jīng)濟(jì)運(yùn)行任務(wù),。
 
9 - 懂得何時使用匯編程序
 
C或C++可以立即帶來速度提升,而不需要編寫比Java要難以維護(hù)的代碼,。也可通過將代碼關(guān)鍵部分轉(zhuǎn)換為匯編程序來實(shí)現(xiàn)進(jìn)一步提升,,但需要在耗費(fèi)的時間、精力與最終受益之間做出權(quán)衡,。最好先發(fā)布工作代碼,,在以后發(fā)布快速升級,而不是永無休止的調(diào)試,。盡管如此,,如果您十分清楚想要做什么,也許可以獲得更多性能,。
 
切記要檢查發(fā)布出來的GCC,,這一點(diǎn)至關(guān)重要。objdump是一款非常有用的工具,,谷歌NDK下載目錄位于build/prebuilt/linux-x86/arm-eabi-4.4.0/arm-eabi/bin下提供了一種版本,。
 
10 - 懂得如何使用NEON
 
NEON是一個非常強(qiáng)大的工具,在理想環(huán)境中,,可給優(yōu)化匯編程序提供8倍的性能提升,,但并不適用于所有環(huán)境。要了解如何充分利用NEON,,請閱讀本博客中的NEON指南,。
NEON加載和存儲處理遺留工作
 
 
Dave,ARM首席工程師,,致力于虛擬機(jī)的維護(hù),、優(yōu)化、檢查至少十年,,為硬件工程師解答有關(guān)虛擬機(jī)的問題,。在Java領(lǐng)域經(jīng)營多年后,他得以抽出時間研究工具,,現(xiàn)在正著力于研究并理解Android,。
本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,,并不代表本網(wǎng)站贊同其觀點(diǎn),。轉(zhuǎn)載的所有的文章、圖片,、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有,。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容,、版權(quán)和其它問題,,請及時通過電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,,避免給雙方造成不必要的經(jīng)濟(jì)損失,。聯(lián)系電話:010-82306118;郵箱:[email protected],。