每一個人都知道,提升編程能力的顯著方法是寫更多代碼。然而,我保證可以提升編程能力的另外一種方法卻不是寫代碼。我會盡我所能說明這一點:程序員
若是你想大幅提升本身的編程能力,你須要閱讀別人的代碼。編程
無論你之前是否是這樣想的,如今你應該接受這個觀點。若是你願意嘗試一下,那麼你將會收穫頗豐。app
在這篇文章中,我會幫助你選擇閱讀哪些代碼而且給出如何閱讀代碼的實用建議。若是你已是一個代碼閱讀者,你可能已經找到了一些有效的方法,不然,我以爲你應該開始閱讀代碼。框架
這是一個重大的決定,也是一個很難提出建議的決定。因爲閱讀什麼代碼歸根結底與你的工做有關,因此我不會簡單的指出我認爲你應該讀的具體代碼。然而,我將會提供給你一些閱讀代碼的參考。編輯器
閱讀使用的插件或庫是一個很好的開始。ide
這些都是很好的選擇。你已經很熟悉它們的公共 API,這樣會下降對內部工做機制的理解障礙。此外,做爲代碼的使用者,你有機會添加文檔、實現新功能或以某種方式爲項目貢獻代碼。函數
我記得第一次看到 280 Slides 的情景,當時我告訴本身「這真的使人印象深入」。我很快了解到它是一個由開源 Cappuccino 項目框架開發的網站,我將它牢記於心,當我再次遇到一個使人印象深入的 app 也使用 Cappuccino 框架時,我知道我能夠從這個項目中學到不少。最近令你印象深入的是什麼?它是開源代碼嗎?若是是,那麼它將是一個很好的選擇,由於代碼可能會與應用同樣令你印象深入。工具
若是你已經使用開源軟件寫了一段時間代碼,你可能會有一些崇拜的程序員。我能想到幾個使人羨慕的代碼開發者。學習
若是你沒有一個崇拜的開發者,你也能夠很容易地找到一個。她/他極可能寫了前面兩段提到的代碼(你依賴的代碼、令你印象深入的代碼)。測試
若是你喜歡冒險,你可能會考慮深刻理解一個大型項目,如 Ruby on Rails、Drupal、或者 jQuery。我建議你目前避開這樣的項目,除非你是一個有經驗的代碼閱讀者。
大項目包括更多模塊,你可能掙扎於紛雜的概念,而沒有學到有價值的內容。困惑會令人沮喪,項目越大,越容易產生困惑,從而影響你的閱讀。閱讀小項目的好處就是你能夠很快的瞭解整個程序的邏輯,這樣你就更容易集中精力發現和學習其中的細節。
如今你已經選擇了要讀的代碼,那麼閱讀代碼的最佳方式是什麼呢?
我已經讀過不少的代碼,我能夠給出一些最大限度提升投資回報率的閱讀方法。
我認爲你至少要在宏觀層面瞭解你所讀的代碼。若是不瞭解,建議你閱讀項目網站、教程、文檔或者其它除代碼之外的任何資料。
好了,從宏觀層面瞭解代碼後,我建議你第一步先了解項目的結構。這項工做的工做量取決於你所選擇代碼的規模,任何多於一個文件的項目都須要花一點時間。
首先注意文件結構。這一步可使用一個有文件夾層次結構視圖的編輯器(如 TextMate),好比,這是一個很好的Twitter Ruby gem 總覽。
這一步的目標是熟悉源代碼。找出哪些文件包含/須要/加載其它文件,大部分代碼在哪,使用的命名空間是什麼以及這類性質的內容。一旦瞭解了全局,你就能夠準備深刻挖掘細節了。
閱讀代碼不該該是一個被動行爲。我鼓勵你添加註釋,當開始瞭解程序流程時記錄你的假設和結論。當你第一次開始寫評論時看起來是這樣的:
# I think this function is called after 'initialize'
# 我認爲這個函數在「初始化」以後調用
# What does this equation even do?
# 這個公式是作什麼用的?
# Pretty sure this variable loses scope after line 17
# 很是肯定這個變量在 17 行後失去做用域
隨着你的深刻理解,你能夠刪除本身的用戶評論,寫出能夠反饋給項目的更有意義、更權威的評論。
但願你選擇的項目有測試套件。若是沒有,你徹底能夠跳過這一節(或者找一個有的)。
當你閱讀別人的代碼時,測試是一個很好的開始,由於它們記錄了代碼應該實現的功能。有些測試比其餘信息更豐富,可是無論寫的多好,你常常會發現使用測試比執行代碼更容易瞭解程序員的意圖。當你閱讀時,試着讓測試套件成功運行。這將確保你的開發環境配置正確,並將使你在進行更改時更加自信。
誰說讀代碼就不須要動手?一旦你打破一切再將它們從新整合在一塊兒,你纔開始真正明白。還記得你作過的那些測試嗎?使測試失敗,添加一些新功能,或者嘗試在不破壞的狀況下改變執行。嘗試着添加一些你以爲很酷的小功能,或者設置項目範圍的日誌記錄,這樣能夠在代碼各個階段打印輸出。這仍是閱讀嗎?固然,此時更像是本身在冒險,而不是看一本偵探小說。這是一件好事。
當你讀完一個代碼庫,選擇另一個代碼庫從新開始這個過程。你讀的代碼越多、讀的越好,完成的時間就越短。我想你會發現投資回報率在飛快的增加,這其實是一種很是愉快的學習方式。
羣裏不定時上傳視頻學習資料!
讓本身的技術更上一層樓
相互交流,挑戰高薪!