想快速成為編程高手?這個技巧必不可少!
譯文【51CTO.com快譯】 經(jīng)過這幾年的編程學(xué)習(xí),我認(rèn)為想要提升編碼水平的***途徑就是多看、多寫,然而閱讀別人的代碼也確實(shí)是快速提升代碼水平的一個技巧。在今天的文章中,我將與大家探討如何閱讀別人編寫的代碼。如果大家已經(jīng)擁有這種良好習(xí)慣,那么這些建議也許能夠進(jìn)一步改善您的學(xué)習(xí)效果。
我要明確地表述這種方式的好處:
-
1.如果大家希望能顯著提升編程技能,則需要閱讀其他人的代碼。
-
2.如果大家愿意一試,相信我,這絕對能夠帶來相當(dāng)直觀的提升效果。
如果您還沒有,請別猶豫,馬上嘗試吧。
一、讀什么代碼?
這個問題非常重要,但同時也難以解答。我無法簡單告訴大家應(yīng)該閱讀哪些代碼,因?yàn)橐鶕?jù)個人條件而定。但我接下來,會給出一些宏觀層面的指導(dǎo)意見。
1.閱讀相關(guān)性高的代碼
***的起點(diǎn)就是閱讀您正在使用的插件或者庫中的代碼。
- 您喜愛的WordPress插件代碼。
- 您經(jīng)常使用的Ruby gem代碼。
- 您不斷重復(fù)使用的jQuery插件代碼。
這些都是良好的學(xué)習(xí)素材。由于已經(jīng)熟悉其公共API,因此了解其內(nèi)部工作原理會變得更加簡單。另外,作為代碼用戶,大家也可以為項(xiàng)目添加文檔、實(shí)現(xiàn)新功能或者以其它方式作出貢獻(xiàn)。
2.閱讀令您印象深刻的代碼
我還記得自己***次看到280 Slides時的感受,用“印象深刻”這個詞來形容絕對不夸張。接著我就去了解該站點(diǎn)的驅(qū)動代碼源自開源Cappuccino項(xiàng)目,之后我將這些知識牢記心中,并在我以后的道路也受益很多。相信在大家的從業(yè)經(jīng)歷中,也一定會見到過令您印象深刻的代碼,如果,它屬于開源項(xiàng)目,請務(wù)必認(rèn)真研究并將其融入自己的應(yīng)用開發(fā)當(dāng)中。
3.閱讀您所尊敬的人編寫的代碼
如果大家已經(jīng)擁有一定開源軟件編寫經(jīng)歷,那么無疑已經(jīng)結(jié)識了不少值得膜拜的大牛。我們可以認(rèn)真閱讀他們編寫的代碼,并在贊嘆之余借此充實(shí)自己的頭腦。當(dāng)然,即使沒有,想要找到理想的學(xué)習(xí)對象也絕非難事。
4.閱讀您能夠切實(shí)理解的代碼
很多有冒險(xiǎn)精神的朋友,可能更喜歡直接投身于Ruby on Rails、Drupal或者jQuery等大型項(xiàng)目當(dāng)中。但我個人的建議,是大家***能先從易于理解的代碼入手。
大型項(xiàng)目的活動組件太多,大家可能掙扎于概念當(dāng)中而無法快速汲取經(jīng)驗(yàn)。這種混亂會導(dǎo)致沮喪,甚至在理解當(dāng)中消磨了自己的學(xué)習(xí)熱情。這時如果先挑選小型項(xiàng)目進(jìn)行閱讀,會讓您能夠立刻掌握業(yè)務(wù)邏輯,并專注于研究其中的技術(shù)細(xì)節(jié)。
二、如何閱讀
說到這里,新的問題來了——我們該如何閱讀代碼?我擁有比較豐富的閱讀代碼的經(jīng)驗(yàn),所以下面我要與大家分享自己的一點(diǎn)心得。
閱讀代碼,應(yīng)該是既需要廣度也需要深度
廣度:看的是代碼的整體架構(gòu),比如模塊劃分與組織,設(shè)計(jì)模式的運(yùn)用等等
深度:挑選自己感興趣的模塊,深入理解學(xué)習(xí)他的具體實(shí)現(xiàn)
1.著眼于宏觀
假設(shè)大家已經(jīng)了解了所要閱讀代碼的宏觀作用。如果還沒有,那我建議大家通過網(wǎng)站、教程、文檔乃至其它來源先弄清手頭這些代碼的基本用處。
我認(rèn)為***步應(yīng)該是著眼于項(xiàng)目結(jié)構(gòu)。根據(jù)您所選擇的實(shí)際代碼庫規(guī)模,這***步的實(shí)際強(qiáng)度也有所區(qū)別,不過一般來講應(yīng)該不會耗費(fèi)太多時間。
首先,關(guān)注文件結(jié)構(gòu)。大家可以使用TextMate等擁有文件夾層級視圖的編輯器作為輔助手段。上圖所示即為一份清晰的Twitter Ruby gem視圖。
這一步的目的是熟悉源代碼。了解哪些文件包含/要求/加載其它文件,主體代碼在哪里,是否使用了命名空間等等。了解了這些基本情況下,開始深入細(xì)節(jié)。
2.記錄下您的發(fā)現(xiàn)
閱讀代碼不應(yīng)該是一種被動的行為。我建議大家隨時添加評論,記錄下您的假設(shè)并總結(jié)您理解中的程序流程。您***次閱讀后的結(jié)論可能類似下面這種形式:
- # I think this function is called after 'initialize'
- # What does this equation even do?
- # Pretty sure this variable loses scope after line 17
而在理解了整個進(jìn)程后,您可以清理掉這些評論,或者寫下更有意義且更為準(zhǔn)確的意見。
3.進(jìn)行測試
希望您選定的項(xiàng)目擁有測試套件。如果沒有,大家可以直接跳過此章節(jié)(或者另選一個包含測試套件的項(xiàng)目)。
將測試作為代碼閱讀起點(diǎn)非常重要,因?yàn)槠渲杏涗浟舜a所應(yīng)完成的既定目標(biāo)。而且無論代碼質(zhì)量多高,查看測試結(jié)果都能幫助我們更清晰地理解原程序員的意圖。在閱讀時,確保測試套件能夠正常運(yùn)行,這將保證您當(dāng)前的開發(fā)環(huán)境配置正確。
4.執(zhí)行、變更、再執(zhí)行
誰說閱讀代碼就沒法動手參與?大家可以嘗試改動現(xiàn)有項(xiàng)目再重新調(diào)整,從而真正理解其設(shè)計(jì)思路。大家不妨添加一項(xiàng)小功能,或者設(shè)置更為廣泛的日志記錄機(jī)制,從而輸出各個階段的代碼。如此一來,我們的閱讀過程就更像是參與一場冒險(xiǎn),而非面對一本晦澀的小說。相信我,這種方法非常有效。
5.重復(fù)再重復(fù)
在讀完一套代碼庫后,選擇另一套繼續(xù)進(jìn)行。您閱讀過的代碼越多,您的學(xué)習(xí)速度就越快,并越能夠享受這種愉快的學(xué)習(xí)方式。
三、從哪里入手
我個人的閱讀代碼旅程始于GitHub。找個適合自己的項(xiàng)目,馬上開始學(xué)習(xí)——GitHub是一座巨大的寶庫,感謝開源精神讓我們擁有如此珍貴的資源可供利用!
原文標(biāo)題:One Sure-Fire Way to Improve Your Coding
原文作者:Jerod Santo
【51CTO譯稿,合作站點(diǎn)轉(zhuǎn)載請注明原文譯者和出處為51CTO.com】