當(dāng)前位置:首頁 > 充電吧 > 充電吧
[導(dǎo)讀]那就是去讀別人寫的代碼。讀那些你常用的庫、編程框架的源代碼,讀那些你景仰的大牛的源代碼,讀代碼里的測試(測試本身就是一種有效的文檔);讀代碼、改代碼、運(yùn)行代碼。其實(shí),所謂寫程序,大部分的時(shí)間都是花在讀代碼上,“寫”的部分耗時(shí)極少;所以把“讀”的技能訓(xùn)練好了,是很有好處的。

那就是去讀別人寫的代碼。讀那些你常用的庫、編程框架的源代碼,讀那些你景仰的大牛的源代碼,讀代碼里的測試(測試本身就是一種有效的文檔);讀代碼、改代碼、運(yùn)行代碼。

其實(shí),所謂寫程序,大部分的時(shí)間都是花在讀代碼上,“寫”的部分耗時(shí)極少;所以把“讀”的技能訓(xùn)練好了,是很有好處的。

提高編程能力萬無一失的辦法

編注:這篇文章最初于 2010 年 5 月為 Fuel Your Coding 網(wǎng)站而寫。不幸的是,那個(gè)網(wǎng)站已經(jīng)不復(fù)存在了,所以我將這篇文章重新發(fā)布。為了緊跟時(shí)代步伐,我想過對其進(jìn)行更新,但我又覺得這篇文章經(jīng)得起時(shí)間考驗(yàn)。經(jīng)不起時(shí)間考驗(yàn)的內(nèi)容是有些可笑的,不管怎樣,盡情享受吧。

——-

每個(gè)人都知道,提高編程能力的顯著方法是寫更多代碼。然而,我保證能夠提高編程能力的另一種方法卻不是寫代碼。我會(huì)盡我所能說明這一點(diǎn):

如果你想大幅提高自己的編程能力,你需要閱讀別人的代碼。

不管你以前是不是這樣想的,現(xiàn)在你應(yīng)該接受這個(gè)觀點(diǎn)。如果你愿意嘗試一下,那么你將會(huì)收獲頗豐。

在這篇文章中,我會(huì)幫助你選擇閱讀哪些代碼并且給出如何閱讀代碼的實(shí)用建議。如果你已經(jīng)是一個(gè)代碼閱讀者,你可能已經(jīng)找到了一些有效的方法,否則,我覺得你應(yīng)該開始閱讀代碼。

閱讀哪些代碼

這是一個(gè)重大的決定,也是一個(gè)很難提出建議的決定。由于閱讀什么代碼歸根結(jié)底與你的工作有關(guān),所以我不會(huì)簡單的指出我認(rèn)為你應(yīng)該讀的具體代碼。然而,我將會(huì)提供給你一些閱讀代碼的參考。

閱讀你依賴的代碼

閱讀使用的插件或庫是一個(gè)很好的開始。

一個(gè)你真正喜歡的 WordPress 插件

一個(gè)你發(fā)現(xiàn)有用的 Ruby gem

一個(gè)你一直使用的 jQuery 插件

這些都是很好的選擇。你已經(jīng)很熟悉它們的公共 API,這樣會(huì)降低對內(nèi)部工作機(jī)制的理解障礙。此外,作為代碼的使用者,你有機(jī)會(huì)添加文檔、實(shí)現(xiàn)新功能或以某種方式為項(xiàng)目貢獻(xiàn)代碼。

閱讀令你印象深刻的代碼

我記得第一次看到 280 Slides 的情景,當(dāng)時(shí)我告訴自己“這真的令人印象深刻”。我很快了解到它是一個(gè)由開源 Cappuccino 項(xiàng)目框架開發(fā)的網(wǎng)站,我將它牢記于心,當(dāng)我再次遇到一個(gè)令人印象深刻的 app 也使用 Cappuccino 框架時(shí),我知道我可以從這個(gè)項(xiàng)目中學(xué)到很多。最近令你印象深刻的是什么?它是開源代碼嗎?如果是,那么它將是一個(gè)很好的選擇,因?yàn)榇a可能會(huì)與應(yīng)用一樣令你印象深刻。

閱讀你崇拜的人寫的代碼

 

如果你已經(jīng)使用開源軟件寫了一段時(shí)間代碼,你可能會(huì)有一些崇拜的程序員。我能想到幾個(gè)令人羨慕的代碼開發(fā)者。

如果你沒有一個(gè)崇拜的開發(fā)者,你也可以很容易地找到一個(gè)。她/他很可能寫了前面兩段提到的代碼(你依賴的代碼、令你印象深刻的代碼)。

閱讀你可以理解的代碼

如果你喜歡冒險(xiǎn),你可能會(huì)考慮深入理解一個(gè)大型項(xiàng)目,如 Ruby on Rails、Drupal、或者 jQuery。我建議你目前避開這樣的項(xiàng)目,除非你是一個(gè)有經(jīng)驗(yàn)的代碼閱讀者。

大項(xiàng)目包括更多模塊,你可能掙扎于紛雜的概念,而沒有學(xué)到有價(jià)值的內(nèi)容。困惑會(huì)使人沮喪,項(xiàng)目越大,越容易產(chǎn)生困惑,從而影響你的閱讀。閱讀小項(xiàng)目的好處就是你可以很快的了解整個(gè)程序的邏輯,這樣你就更容易集中精力發(fā)現(xiàn)和學(xué)習(xí)其中的細(xì)節(jié)。

如何閱讀

現(xiàn)在你已經(jīng)選擇了要讀的代碼,那么閱讀代碼的最佳方式是什么呢?

我已經(jīng)讀過很多的代碼,我可以給出一些最大限度提高投資回報(bào)率的閱讀方法。

縱觀全局

我認(rèn)為你至少要在宏觀層面了解你所讀的代碼。如果不了解,建議你閱讀項(xiàng)目網(wǎng)站、教程、文檔或者其它除代碼以外的任何資料。

好了,從宏觀層面了解代碼后,我建議你第一步先了解項(xiàng)目的結(jié)構(gòu)。這項(xiàng)工作的工作量取決于你所選擇代碼的規(guī)模,任何多于一個(gè)文件的項(xiàng)目都需要花一點(diǎn)時(shí)間。

首先注意文件結(jié)構(gòu)。這一步可以使用一個(gè)有文件夾層次結(jié)構(gòu)視圖的編輯器(如 TextMate),比如,這是一個(gè)很好的Twitter Ruby gem 總覽。

這一步的目標(biāo)是熟悉源代碼。找出哪些文件包含/需要/加載其它文件,大部分代碼在哪,使用的命名空間是什么以及這類性質(zhì)的內(nèi)容。一旦了解了全局,你就可以準(zhǔn)備深入挖掘細(xì)節(jié)了。

記錄你的發(fā)現(xiàn)

閱讀代碼不應(yīng)該是一個(gè)被動(dòng)行為。我鼓勵(lì)你添加注釋,當(dāng)開始了解程序流程時(shí)記錄你的假設(shè)和結(jié)論。當(dāng)你第一次開始寫評論時(shí)看起來是這樣的:

隨著你的深入理解,你可以刪除自己的用戶評論,寫出可以反饋給項(xiàng)目的更有意義、更權(quán)威的評論。

使用測試,Luke(用于方便開發(fā)和診斷的第三方工具)

希望你選擇的項(xiàng)目有測試套件。如果沒有,你完全可以跳過這一節(jié)(或者找一個(gè)有的)。

當(dāng)你閱讀別人的代碼時(shí),測試是一個(gè)很好的開始,因?yàn)樗鼈冇涗浟舜a應(yīng)該實(shí)現(xiàn)的功能。有些測試比其他信息更豐富,但是不管寫的多好,你經(jīng)常會(huì)發(fā)現(xiàn)使用測試比執(zhí)行代碼更容易了解程序員的意圖。當(dāng)你閱讀時(shí),試著讓測試套件成功運(yùn)行。這將確保你的開發(fā)環(huán)境配置正確,并將使你在進(jìn)行更改時(shí)更加自信。

執(zhí)行,改變內(nèi)容,執(zhí)行

誰說讀代碼就不需要?jiǎng)邮?一旦你打破一切再將它們重新整合在一起,你才開始真正明白。還記得你做過的那些測試嗎?使測試失敗,添加一些新功能,或者嘗試在不破壞的情況下改變執(zhí)行。嘗試著添加一些你覺得很酷的小功能,或者設(shè)置項(xiàng)目范圍的日志記錄,這樣可以在代碼各個(gè)階段打印輸出。這還是閱讀嗎?當(dāng)然,此時(shí)更像是自己在冒險(xiǎn),而不是看一本偵探小說。這是一件好事。

沖洗和重復(fù)

當(dāng)你讀完一個(gè)代碼庫,選擇另外一個(gè)代碼庫重新開始這個(gè)過程。你讀的代碼越多、讀的越好,完成的時(shí)間就越短。我想你會(huì)發(fā)現(xiàn)投資回報(bào)率在飛快的增長,這實(shí)際上是一種非常愉快的學(xué)習(xí)方式。

從哪兒開始

對我閱讀代碼影響最大的是 GitHub。在這個(gè)網(wǎng)站上,我們可以很容易的找到新項(xiàng)目和偉大的程序員,如果不好好利用它那將是在為自己幫倒忙。我建議先在 GitHub 網(wǎng)站上閱讀代碼直到找到自己可以借鑒的項(xiàng)目,然后用 git clone 復(fù)制這個(gè)項(xiàng)目并開始閱讀!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉