雖然Android智能手機和平板電腦的速度一天比一天快,但是開發人員必須記住一點:他們開發的應用程式仍在一種資源緊張的環境下運行,這種環 境主要依賴效能與最新的台式機或膝上型電腦無法比擬的電池和處理器。下面介紹的一些方法可以協助你的應用程式“瘦身”或者說“Android提升開發效能 十大要點”,以便它們在今天和明天的Android裝置上最順暢地運行。
先來說說確保應用程式響應迅即的幾個編程要點。
第一個要點:首先要有良好的編程習慣
要成為一名優秀的資源管理員;既要運用常識,還要使用公認的演算法和標準的設計模式。在資源使用方面,如果你開啟了資源,要記得關閉資源。要盡量 晚地擷取,盡量早地釋放。這些由來已久的編程準則同樣適用於你的Android應用程式,如果它們使用底層的裝置服務,更是如此。
比如說,假設你編寫的一個應用程式依賴基於位置的服務。除非你絕對有必要,否則不要開始註冊、擷取位置最新資訊;而且要確保,一旦你不再需要這些資訊,就要取消擷取最新資訊的註冊。這將協助你避免不必要地耗費裝置電池電量或佔用系統資源。
第二個要點:讓阻塞操作遠離主使用介面執行緒
想確保你的應用程式運行起來很靈活,就要使用AsyncTask、線程、IntentService或自訂後台服務來處理髒活。應使用裝入器來簡化裝入時間長的資料(如遊標)的狀態管理。你無法容忍你的應用程式在某個操作正在處理的時候出現滯後或停頓。
如果某個操作很費時間和資源,就要卸載這部分操作、對它進行非同步處理,那樣你的應用程式仍保持響應迅即,使用者可以處理他們的事務。這個原則適用於下列操作:磁碟讀寫,訪問內容提供方、資料庫和互連網,以及解析和其他長時間的任務。
第三個要點:使用最新的Android軟體開發套件(SDK)版本、應用編程介面(API)和最佳實務
確保你開發的應用程式是最新的,因而要使用Android平台提供的最新工具。隨著Android平台不斷髮展,它也在不斷改進。一些功能可能 已被棄用,或者換成了更好的功能。核心API得到了修正版(bug fix)和效能改進。已經引入了裝入器等新的API,協助開發人員編寫出運行更穩定、響應更迅即的應用程式。
你知道可以啟用Android3.0應用程式中的硬體加速功能嗎?趕緊啟用吧!要明白最佳實務會隨著時間的變化而變化。明智的開發人員密切關注Android平台的新功能、哪些功能不再被推薦。
第四個要點:考慮使用限制模式(Strict Mode)
你可以使用名為限制模式(StrictMode)的AndroidAPI,協助你查明哪裡違反了幾個良好的編程習慣。StrictMode會幫 助你確認你的應用程式是不是存在記憶體流失,並且檢測你的應用程式是不是在試圖執行長時間的阻塞操作,這些操作應該被卸載到線程或別的渠道(參閱第二個要 點)。
Android2.3裡面引入StrictMode類(android.os.StrictMode)。
第五個要點:在發布應用程式之前,禁用或盡量少用調試和診斷
如果你的Android應用程式開發起來需要一些時間,你可能已將一些日誌和調試代碼嵌入到了應用程式中。寫入到日誌及其他此類輸出系統給效能帶來了影響。確保在發布應用程式之前,盡量少用或完全禁用這些功能。
現在不妨說說如何運用良好的使用者介面設計原則,讓你應用程式的螢幕更快速地裝入:
第六個要點:確保你設計的布局簡單、簡練和淺層
簡單的螢幕有助於閱讀起來最輕鬆,而簡單的布局裝入起來最快速。你不應該過於深層地嵌套你的布局,或者用不必要的過多視圖(View)控制項塞滿 螢幕。花些時間來開發使用者可以高效使用的簡練使用者介面,而不是試圖把太多功能塞入到單單一個螢幕上。這不但有助於提升應用程式的效能,還有助於讓你的應用 程式對使用者來說更高效。
有助於在不影響靈活地針對不同類型的裝置進行設計的情況下,劃分使用者介面功能。
第七個要點:讓你應用程式的資源適合目標裝置
添加適合特定裝置配置的資源,那樣它們就能儘可能高效地裝入。我們在談論圖形資源時,這點尤為重要。如果你添加了可利用的龐大映像資源,需要裝入和調整大小,就無法有效地使用其他的應用程式資源。
另一個要點就是,如果你準備你的應用程式可以在許多裝置上運行,為了讓應用程式軟體包檔案保持合理的大小,應該最初只添加運行應用程式所需要的核心資源,然後讓應用程式下載適合該裝置的內容。
第八個要點:使用Hierarchy Viewer工具
Hierarchy Viewer工具可以協助你調試你的應用程式布局。它還提供了寶貴的分析資訊,以便瞭解布局裡面的每一個視圖控制項測量、渲染和繪製要花多少時間。只有準確找到了問題的根源,問題解決起來才容易。
第九個要點:使用layoutopt工具
Layoutopt工具是一款簡單的命令列工具,它可以協助你找到不必要的控制項嵌套以及縮減布局資源的其他方法,以便盡量減少資源的使用。它讓你可以瞭解哪些布局控制項可能是多餘的或不必要的。控制項越少、布局層次越淺,效能就越好。
最後,你認為你的應用程式做到了最好嗎?現在該對它測試一下了。
第十個要點:使用Traceview及其他Android工具進行分析
Android SDK隨帶了許多工具,可用來對你的應用程式進行分析。其中最流行的工具恐怕莫過於Traceview,這款圖形化工具可以協助你調試和找到應用程式中的效能瓶頸。不妨看看Android說明文檔中介紹的一些調試工具。
結束語
有許多方法可以協助你提升Android應用程式的效能。有些需要使用特定的演算法,有些依賴切實可行的調試和效能監測技巧。幸好,Android平台隨帶眾多免費的工具 + 生產力,可以協助你查明和消除應用程式裡面的效能問題。既然有了這些工具,就要立馬使用!