優秀程序員之道:深入理解你的代碼

n6xb 9年前發布 | 13K 次閱讀 程序員

為什么有些程序員似乎有著一種神奇的能力,能夠在眨眼間提取代碼的意思?

為了回答這個問題,我先從科學的角度來研究我們理解代碼的過程。

事實證明,理解代碼是有其心理過程的,我們可以利用這方面的知識成為一名更優秀的程序員。它能有助于你理解開發過程中的各個環節,這樣你就不會因為編程中的技術瓶頸而裹足不前。

優秀程序員之道:深入理解你的代碼

本文將對有關編程理解的知識略有涉及,并從三個方面來討論如何利用這些知識成為一名更優秀的程序員。

關于成為更優秀的程序員的方法有三種:

首先,你得知道理解代碼的能力取決于三個方面:

  1. 知識——解決問題所需要的模塊
  2. 鏈接——模塊之間的膠水
  3. 假設——形成鏈接的工具
  4. </ol>

    所以很顯然,提高編程能力需要更全面的方法途徑。

    1.獲取更多的一般知識

    既然理解代碼的能力依賴于現有知識與問題之間的匹配數量,那么由此我們可以推出,掌握的知識越多,成功的可能性越大。

    作為程序員,我們很有必要花費大量的時間來獲取新知識。并且我們需要關注的,更多的是原理而不是技術。

    考慮到這一點,讓我們來看看我們需要囊括其中的一些知識:

    語言的具體知識

    語言的具體知識是許多開發人員關注的重點。

    了解語言和框架的底細。去了解API和語言結構,尋找陌生語言的不同之處,知道內部的工作原理。

    通常有很多課程和信息有助于我們掌握這方面的知識。

    這類知識的問題是,不斷地會有新知識出現。新框架、語言的新版本……并且,時間越久,這方面的知識就越不值錢。

    編程概念

    這種類型的知識擁有更長的保質期。

    學校教育中的計算機科學學位用了大量的時間來講述這方面的內容。在學習語言和框架的同時,也能學到概念知識。但是從語言和框架中學習概念有一個問題,那就是有時候你會很難將基本概念從它的語法表達中剝離開來。

    不同的語言對某些概念的表達也有好有壞。所以了解幾個不同的框架和語言是有好處的。還有一種方法是先學概念,然后再去學習它是如何應用于不同的語言的。但是這種途徑的教材和信息比較難找。編程概念包括諸如模式、算法、數據結構等等。

    領域知識

    對行業的了解能為你提供一系列額外的非編程概念,可用于構建心理模型。

    2.更善于代碼和一般知識之間的匹配

    充足的一般知識,能讓你得到更善于匹配。因為你知道如何從代碼中尋找線索,識別線索,并迅速提取代碼的含義。

    學會識別代碼標識

    代碼標識是一種能暗示基本概念的模式。這些模式可以跨越不同的復雜度。它們是一類能夠指引更高層次概念的代碼片段。

    例如,當你看到如下模式的代碼:

    “ Iterate over the elements in an array
    Put elements into a new array based on a condition

    </blockquote>

    那么你就應該知道你正在處理過濾器。

    直接將這個代碼模塊定義為“過濾器”,而不是“使用if條件從舊數組中取一些項目放到新數組中的循環”,能夠避免走彎路的時間。

    在傳統的軟件開發中,“模式”參考了經典書籍《 Design Patterns: Elements of Reusable Object-Oriented Software》中的相關內容。但是,代碼標識雖然和設計模式有關,但卻是不同的東西。

    在以后的文章里,我將羅列一些代碼標識,并解釋如何識別它們。

    學習語言規則

    所謂的語言規則指的是在框架和編程語言中使用的約定和編碼風格。比如我們在Ruby和C#中的命名方式就是不一樣的。再如Rails喜歡使用MVC模式,但其他框架則不(例如Meteor.js)。

    遵循語言規則編碼能讓代碼更易于理解。即使是專業人士也是如此。

    語言規則是需要日積月累的,我們可以從代碼示例和同事身上學到這些規則。如果是新語言和框架,那就需要格外關注。

    3.更善于制定和修改假設

    一開始制定的假設越趨于正確,你就能越快地構建起心理模式來。

    使用系統化的方法

    用系統化的方法來建立心理模型包括讀取每一行的代碼,重點構建你需要的知識。此方法的效果最好,但對于大型的代碼庫未免有點不切實際。系統化的方法 最適用于那種規模大小可控的高度關鍵代碼。但是這樣的理想情況在現實世界中是很少見的。通常你需要處理的都是那些已經經過多年亂七八糟擴展的大型代碼庫。

    使用投機型的方法

    至于投機型的方法——尋找感興趣的代碼片段,對此代碼的目的做一個假設,然后深入挖掘,看看你的假設是否正確。善于識別代碼標識無論是在語法層面,還是在更高層次的抽象層面,都能有助于你形成更好的假設。

    這方法當然沒有全面理解代碼的效果好,但是相對的理解起來要快得多。這也很容易因為快速修復而破壞部分系統,所以要小心。

    要想成為世界級的程序員,你需要掌握以上三個方法

    我們都希望自己能成為最好的程序員。而在當今的技術世界里,要想有所成就,你就得跟上不斷出現的新框架和新理論的腳步。幸運的是,這是有捷徑可循的。如果你目的明確,并且能意識到自己的缺點,那么在相同的努力下,你可以獲得更大更快的進步。

    在我看來,區分一個程序員是真的優秀還是流于表面的優秀,關鍵在于其對編程核心概念的理解。

    歡迎評論。

    </div> 譯文鏈接: http://www.codeceo.com/article/become-a-better-programmer-by-learning-code.html
    英文原文: How to Become a Better Programmer by Learning How You Understand Code
    翻譯作者: 碼農網 – 小峰

     本文由用戶 n6xb 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
     轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
     本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!