網(wǎng)上閱讀時(shí)獵取到的一篇外國工程師的文章,作者 César Ferreira 結(jié)合自己在安卓領(lǐng)域的摸爬滾打經(jīng)歷總結(jié)了三十多條寶貴經(jīng)驗(yàn),非常值得參考學(xué)習(xí),故翻譯記錄于此,并作了一些補(bǔ)充說明,幫助閱讀理解。譯文原文:
轉(zhuǎn)自:http://yifeng.studio/2016/10/27/android-develop-30-things-that-experience-made-me-learn-the-hard-way/
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(cuò)誤也許就發(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)化布局,以便你能一眼識別出冗余的視圖并移除;
如果你使用gradle
,想盡一切辦法加快編譯速度;(參考文章:How I save 5h/week on Gradle builds)
使用 PRofile report 查看編譯時(shí)間到底是在什么地方耗費(fèi)的;
盡量使用眾所周知的成熟架構(gòu)體系;(參考文章:Architecting Android…The evolution)
測試消耗時(shí)間,但是一旦你掌握了測試的竅門就會發(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,一個(gè)專屬安卓開發(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è)計(jì)模式,封裝等)
保持學(xué)習(xí)最新開源類庫,并借助 dryrun 工具測試開源類庫;(Android Arsenal,一個(gè)搜索整合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)時(shí)間的任務(wù)。使用circleci
、travis
和 shippable
,相比而言,性價(jià)比更高,更可靠;
使用 gradle-play-publisher 自動部署上傳Apk文件等信息到應(yīng)用商店;
如果一個(gè)library比較大,而你只是用到其中的一小部分功能,那么你就應(yīng)該尋找一個(gè)更小的替代品;(比如可以借助 proguard 工具)
不要大量使用超出你實(shí)際需要的依賴庫。特別是當(dāng)這些依賴庫不是經(jīng)常在變時(shí),我們就要考慮到,這些類庫從頭編譯( CI Builds
就是一個(gè)很好的例子)或者檢查之前編譯好的獨(dú)立類庫是否需要更新所花費(fèi)的時(shí)間相比簡單地加載jar或者aar這樣的二進(jìn)制文件,高達(dá)四倍之多;
開始考慮使用 SVG 代替 PNG 格式的圖片;(參考地址:Add Multi-Density Vector Graphics)
封裝抽象化 library 的使用,這樣當(dāng)你需要使用新的 library 替代舊 library 時(shí)就會變得很容易;
監(jiān)聽網(wǎng)絡(luò)連接變化和連接類型(Wifi狀態(tài)下數(shù)據(jù)更新更頻繁?);
監(jiān)聽電源和電池電量變化(充電時(shí)數(shù)據(jù)更新更頻繁?電池電量不足時(shí)暫停更新?);
展現(xiàn)給用戶的UI就像一個(gè)笑話,如果你不得不解釋一下的話,它就不是一個(gè)好笑話;
性能測試很重要:Coding 實(shí)現(xiàn)慢,但要正確,然后驗(yàn)證優(yōu)化,這不會影響任何測試內(nèi)容。
新聞熱點(diǎn)
疑難解答