Android程序員提高編程效率之九議
作為一個(gè)熱愛(ài)文學(xué)的Android程序員,我堅(jiān)信古往今來(lái)最遺憾的戰(zhàn)略就是辛棄疾的《九議》,連辛棄疾的敵人滅亡南宋后都感慨:“使宋果用之,吾安得至此?”。盡管我沒(méi)有帶著一大堆種樹(shù)書(shū)穿越回去改寫(xiě)“卻將萬(wàn)字平戎策,換得東家種樹(shù)書(shū)”的歷史的機(jī)會(huì),但我可以為廣大Android程序員策劃了九條提高編程效率的方案,讓大家在提高編程效率的路上少走幾步彎路。
本文引用地址:http://2s4d.com/article/201710/369934.htm
【圖:Android Studio的界面】
一、精良的開(kāi)發(fā)工具
所謂“工(程師)欲善其事,必先利其(編譯)器”,想要提高寫(xiě)代碼的效率,必須先改良自己寫(xiě)代碼的工具,所謂工具包括但不限于可以摸的機(jī)械鍵盤(pán)、人體工學(xué)座椅、程序員鼓勵(lì)師(好像有什么奇怪的東西混進(jìn)來(lái)了),更重要的是IDE、AVD和VCS等軟件。
只要不是在特別坑爹的團(tuán)隊(duì),Android開(kāi)發(fā)的IDE一定是Android Studio,而同樣使用Android Studio的程序員的編程效率的差距就體現(xiàn)在“File->Setting”上,給Android Studio設(shè)置大點(diǎn)的字號(hào)和柔和點(diǎn)的顏色能給你的眼睛一個(gè)舒服的開(kāi)發(fā)環(huán)境。Android Studio也有豐富的插件,比如,合理利用這些插件能讓你的編程工作事半功倍。
即使在一個(gè)崗位只有一個(gè)人的小團(tuán)隊(duì),VCS也是不可或缺的。VCS的意義不止代碼備份和共享那么簡(jiǎn)單,版本分支的管理也離不開(kāi)它。目前最常見(jiàn)的VCS是Git,如果你是一個(gè)懷舊的程序員,也可以選擇SVN。
二、寫(xiě)代碼之前的準(zhǔn)備工作
在寫(xiě)代碼之前,盡可能排除妨礙編程效率的不穩(wěn)定因素也是提高編程效率的因素之一。
開(kāi)始編程之前最重要的準(zhǔn)備工作就是和產(chǎn)品經(jīng)理溝通,明確需求,排除不靠譜的需求。如果遇到必須要在需求不靠譜的情況下立即開(kāi)始開(kāi)發(fā)的情況,比如RecyclerView的item左拉既是翻到下一個(gè)tab又是拉開(kāi)右邊“刪除”和“收藏”的抽屜(和iOS保持一致)的操作等不靠譜需求要盡可能拖著,拖到最后說(shuō)不定就不用做了。
開(kāi)始編程之前準(zhǔn)備工作的第二步就是要準(zhǔn)備好一些技術(shù)難題的前期調(diào)查和解決方案,比如自動(dòng)填寫(xiě)短信驗(yàn)證碼如何繞過(guò)權(quán)限驗(yàn)證、利用ThreadPool分批上傳大文件如何斷點(diǎn)續(xù)傳等,這些問(wèn)題不要等到開(kāi)始編程的時(shí)候才去想。
開(kāi)始編程之前最后一項(xiàng)準(zhǔn)備工作就是寫(xiě)出偽代碼,不要嫌寫(xiě)兩份幾乎一模一樣的代碼麻煩,不提前發(fā)現(xiàn)自己眼高手低更降低編程效率。
三、設(shè)計(jì)模式和架構(gòu)
設(shè)計(jì)模式是一套被反復(fù)使用、多數(shù)人知曉的、經(jīng)過(guò)分類編目的、代碼設(shè)計(jì)經(jīng)驗(yàn)的總結(jié),強(qiáng)調(diào)的是針對(duì)單一問(wèn)題的解決方法。。盡管使用設(shè)計(jì)模式能提高開(kāi)發(fā)效率,但因?yàn)楹芏嘣O(shè)計(jì)模式都是犧牲運(yùn)行性能換取開(kāi)發(fā)效率的,所以必須謹(jǐn)記不要濫用設(shè)計(jì)模式。
架構(gòu)是高層次的針對(duì)體系結(jié)構(gòu)的一種設(shè)計(jì)思路,多種設(shè)計(jì)模式的合理組合就成了架構(gòu)。目前Android最流行的架構(gòu)是MVP,當(dāng)然小而美的App可以選擇更簡(jiǎn)單的MVC架構(gòu),而功能齊全的百科全書(shū)式App則要選擇條理更清晰的MVVM架構(gòu)。
四、清晰的注釋
好的注釋是不一定要長(zhǎng),但一定要精。一目了然、簡(jiǎn)明扼要的注釋能大大提高明天(或者下個(gè)月,反正是未來(lái)時(shí)間)的編程效率;而不好的注釋卻能讓你維護(hù)自己寫(xiě)的爛代碼時(shí)感受到一股跨越時(shí)空的惡意。注釋不是萬(wàn)能的,比如“以下所有l(wèi)eft代表右,所有right代表左”的注釋肯定不如把left和right重新定義一遍對(duì)編程效率的益處大。
五、開(kāi)源代碼和第三方服務(wù)
GitHub上Android的開(kāi)源框架和工具類數(shù)量?jī)H次于JavaScript,浩如煙海的開(kāi)源代碼不但可以讓程序員的編程效率提高,學(xué)習(xí)開(kāi)源代碼的原理和變化更是一個(gè)提高自身能力的過(guò)程。
很多常見(jiàn)的功能,比如推送、短信驗(yàn)證碼、第三方登錄、社交分享、LBS、IM、Crash分析、移動(dòng)廣告等都是第三方服務(wù)的用武之地,公司不大到一定規(guī)模誰(shuí)也不會(huì)自己搭建IM服務(wù)器吧!第三方SDK魚(yú)龍混雜,有些第三方SDK能讓你三天兩頭遇到莫名其妙的bug,但更多的第三方SDK能助你提高開(kāi)發(fā)的效率。
六、老代碼的大規(guī)模重構(gòu)
所謂重構(gòu),就是改進(jìn)已經(jīng)寫(xiě)好的軟件的設(shè)計(jì)。最常見(jiàn)的原因就是隨著依賴的庫(kù)的版本的更新,老的代碼變得不合時(shí)宜,比如OkHttp 3.5以后的版本的WebSocket操作就不需要插件實(shí)現(xiàn)了,我們?cè)谝蕾嘜kHttp 3.7的時(shí)候就要改寫(xiě)OkHttp 3.4.1時(shí)候的WebSocket有關(guān)的代碼。
大規(guī)模重構(gòu)的另一個(gè)原因是前任程序員水平的問(wèn)題,很多“面向百度編程”的程序員離職后交給現(xiàn)任程序員的是一個(gè)千瘡百孔的爛攤子。我見(jiàn)過(guò)同一個(gè)App同時(shí)依賴Glide和Fresco的情況,因?yàn)榍叭螌?shí)現(xiàn)圖片的模糊特效只會(huì)用Fresco,實(shí)現(xiàn)圖片的多點(diǎn)觸摸只會(huì)用Glide。重構(gòu)這些代碼不僅能解決App臃腫的問(wèn)題,也能提高我們接下來(lái)工作中的編程效率。
七、培養(yǎng)新人
在IT社區(qū)分享開(kāi)源代碼,是幫助陌生的同行;在團(tuán)隊(duì)里培養(yǎng)新人,是幫助比你工作年限短的同事。不常用的異常解決方案分享給同事,自己的記憶也會(huì)變得越發(fā)深刻;反之如果生怕同事的技術(shù)水平超過(guò)自己而不肯培養(yǎng)新人,那么請(qǐng)牢記這個(gè)典故:外國(guó)的希臘火、我國(guó)的黑火藥都在不同的歷史時(shí)期多次被“重新發(fā)明”,生怕別人知道,保密保得連自己都忘了。
培養(yǎng)新人還有一個(gè)好處,就是把簡(jiǎn)單、重復(fù)但手生就容易出錯(cuò)的工作讓新人去坐,既能讓他牢記layout_gravity和gravity的區(qū)別,又能給你自己騰出研究如何實(shí)現(xiàn)dex差量替換和gc原理的時(shí)間,是一個(gè)一舉兩得之舉。
八、保持身體健康
身體是革命的本錢(qián),好身體是好的工作、學(xué)習(xí)狀態(tài)的基礎(chǔ)。程序員是大腦發(fā)達(dá)、四肢簡(jiǎn)單的腦力工作者,身體常常處于亞健康狀態(tài),對(duì)編程效率有嚴(yán)重的負(fù)面影響。為了坐在辦公的條件下保證身體健康,我們可以多喝水,既能改善血液循環(huán),又能增加起身上廁所的次數(shù);在屏幕前擺一盆多肉植物,既能吸收讓皮膚變得暗淡油膩的輻射,又能緩解視覺(jué)疲勞。
九、無(wú)憂熊編程法
所謂無(wú)憂熊編程法,就是在辦公桌或者電腦機(jī)箱上擺一只憨態(tài)可掬的無(wú)憂熊,當(dāng)你遇到bug或者瓶頸的時(shí)候,你把你的每一行代碼的作用或者每一行l(wèi)ogcat的問(wèn)題都和它說(shuō)說(shuō),很可能它就會(huì)發(fā)動(dòng)神奇的技能,讓你一下子恍然大悟。這不是封建迷信,如果你上學(xué)時(shí)候曾經(jīng)是學(xué)霸,你一定有過(guò)這樣的經(jīng)歷:暗戀的女生請(qǐng)教你一個(gè)問(wèn)題,你手舞足蹈給她講解:第一遍她沒(méi)懂,第二遍她沒(méi)懂,第三遍你自己懂了。
評(píng)論