網(wǎng)上閱讀時獵取到的一篇外國工程師的文章击纬,作者César Ferreira結(jié)合自己在安卓領(lǐng)域的摸爬滾打經(jīng)歷總結(jié)了三十多條寶貴經(jīng)驗(yàn),非常值得參考學(xué)習(xí)誊垢,故翻譯記錄于此掉弛,并作了一些補(bǔ)充說明,幫助閱讀理解喂走。譯文原文:
Building Android Apps?—?30 things that experience made me learn the hard way
學(xué)習(xí)領(lǐng)域有兩種人殃饿,一種是自身刻苦鉆研一步一步摸索的人,一種是采取捷徑獲取別人經(jīng)驗(yàn)的人芋肠。下面是我一路學(xué)到的東西乎芳,和你分享:
添加使用第三方類庫前,請?jiān)偃伎继兀娴暮苤匾位螅唬ㄎ磥硪恍┪粗腻e誤也許就發(fā)生在這些類庫中,關(guān)于第三方類庫的選擇睡汹,參考文章:stormzhang-如何正確使用開源項(xiàng)目肴甸?)
用戶看不到的地方,就不要去畫它囚巴;(避免過度繪制原在,參考文章:Optimizing Layouts in Android – Reducing Overdraw)
除非真的需要,否則不要使用數(shù)據(jù)庫彤叉;
應(yīng)用中65K的方法數(shù)很快就能達(dá)到庶柿,我的意思是真的很快!不過multidexing也許能幫到你秽浇;(最近剛總結(jié)過一篇:Android 突破64K方法數(shù)的限制)
RxJava絕對是
AsyncTasks
等絕大多數(shù)類最好的替代品浮庐;(參考文章:Party tricks with RxJava, RxAndroid & Retrolambda)Retrofit是最優(yōu)秀的網(wǎng)絡(luò)框架;(沒有之一)
使用Retrolambda縮減你的代碼柬焕;
感受
RxJava
與Retrofit
和Retrolambda
一起使用的魅力审残;(參考文章:參考文章:Party tricks with RxJava, RxAndroid & Retrolambda)我使用EventBus梭域,它很強(qiáng)大,但我不會過度使用维苔,因?yàn)樗鼤勾a庫會變得很雜亂無章碰辅;
根據(jù)應(yīng)用功能分包,而不是所屬類別介时;(項(xiàng)目目錄結(jié)構(gòu)劃分,參考文章:Package by features, not layers)
移除Application線程里的一切代碼凌彬;(避免拖慢應(yīng)用的初始化和啟動速度)
使用lint優(yōu)化布局沸柔,以便你能一眼識別出冗余的視圖并移除;
如果你使用
gralde
铲敛,想盡一切辦法加快編譯速度褐澎;(參考文章:How I save 5h/week on Gradle builds)使用Profile report查看編譯時間到底是在什么地方耗費(fèi)的;
盡量使用眾所周知的成熟架構(gòu)體系伐蒋;(參考文章:Architecting Android…The evolution)
測試消耗時間工三,但是一旦你掌握了測試的竅門就會發(fā)現(xiàn),它比沒有經(jīng)過測試的代碼更快更穩(wěn)妥先鱼;(參考地址:http://stackoverflow.com/questions/67299/is-unit-testing-worth-the-effort/67500#67500
使用
依賴注入
使你的應(yīng)用更加模塊化俭正,并且更容易測試;(參考文章:Tasting Dagger 2 on Android)關(guān)注Fragmened Podcast對你大有幫助焙畔;(Fragmented掸读,一個專屬安卓開發(fā)者的播客網(wǎng)站)
永遠(yuǎn)不要使用私人郵箱作為安卓市場的發(fā)布者賬號;(主要是Google Play宏多,案例參考:https://www.reddit.com/r/Android/comments/2hywu9/google_play_only_one_strike_is_needed_to_ruin_you/)
堅(jiān)持使用合適的輸入類型儿惫;(針對輸入框,參考鏈接:Specifying the Input Method Type)
學(xué)會借助分析學(xué)尋找通用模式和孤立問題伸但;(設(shè)計模式肾请,封裝等)
保持學(xué)習(xí)最新開源類庫,并借助dryrun 工具測試開源類庫更胖;(Android Arsenal
铛铁,一個搜索整合Android開源類庫的網(wǎng)站)Service服務(wù)應(yīng)該做它們需要做的事情,并且盡可能快地終止函喉;
使用 Account Manager 提示用戶名和郵箱地址避归;
使用CI(持續(xù)集成)編譯構(gòu)建測試版和發(fā)布版應(yīng)用;
不要運(yùn)行你自己的
CI server
管呵,防止SSL攻擊而造成的磁盤空間梳毙、安全問題、服務(wù)更新都需要維持server捐下,這是一件耗費(fèi)時間的任務(wù)账锹。使用circleci
萌业、travis
和shippable
,相比而言奸柬,性價比更高生年,更可靠;使用 gradle-play-publisher 自動部署上傳Apk文件等信息到應(yīng)用商店廓奕;
如果一個library比較大抱婉,而你只是用到其中的一小部分功能,那么你就應(yīng)該尋找一個更小的替代品桌粉;(比如可以借助proguard工具)
不要大量使用超出你實(shí)際需要的依賴庫蒸绩。特別是當(dāng)這些依賴庫不是經(jīng)常在變時,我們就要考慮到铃肯,這些類庫從頭編譯(CI Builds就是一個很好的例子)或者檢查之前編譯好的獨(dú)立類庫是否需要更新所花費(fèi)的時間相比簡單地加載jar或者aar這樣的二進(jìn)制文件患亿,高達(dá)四倍之多;
開始考慮使用SVG代替PNG格式的圖片押逼;(參考地址:Add Multi-Density Vector Graphics)
封裝抽象化library的使用步藕,這樣當(dāng)你需要使用新的library替代舊library時就會變得很容易;
監(jiān)聽網(wǎng)絡(luò)連接變化和連接類型(Wifi狀態(tài)下數(shù)據(jù)更新更頻繁挑格?)咙冗;
監(jiān)聽電源和電池電量變化(充電時數(shù)據(jù)更新更頻繁?電池電量不足時暫停更新恕齐?)乞娄;
展現(xiàn)給用戶的UI就像一個笑話,如果你不得不解釋一下的話显歧,它就不是一個好笑話仪或;
性能測試很重要:Coding實(shí)現(xiàn)慢,但要正確士骤,然后驗(yàn)證優(yōu)化范删,這不會影響任何測試內(nèi)容。