相關學習推薦:javascript
#我喜歡編程,它也是我的工作,而且我很高興能夠將大部分的時間都花在開發軟體上。像許多程式設計師一樣,我既著迷但又困惑的是,我寫的程式碼到底怎麼樣,以及如何寫得更好。
多年來,我已經閱讀了許多有關軟體開發的文章和書籍。其中不乏有許多墨寶(書上的或網上的)告訴你如何提高編程,並成為一個像忍者一樣的受過專業訓練的編程高手!這些建議大多有一些共通性,其中之一就是閱讀原始碼。然而相較於其它建議,閱讀原始碼通常也就是簡單的一句話來概括:找一些很棒的開源軟體,或任何你喜歡的軟體,打開它們(或列印出來)然後閱讀它們。雖然總的來說,這確實是個很好的建議,但紙上得來終覺淺,實際去實踐的時候才發現問題多多。在這篇文章中,我會嘗試給出一些閱讀原始碼的實用建議,但在這之前,首先讓我們先列舉一下都有哪些問題。
別人一說閱讀原始碼,給你的一般印像似乎他們就像程式大師一樣,可以單純地坐在椅子上,然後像看小說一樣讀著手上的程式碼。好吧,我敢肯定,確實有一些精湛的程式設計師,他們可以很享受地一邊喝著咖啡、一邊看著一堆類似英語句子的神秘符號,並且還能夠在腦海裡構建整個類的層次和體系結構。顯然這篇文章並不是給他們看的,它的受眾是像我一樣的,覺得盯著一堆源碼看就好比看一些無聊沒有意義的練習題的人。當然,有人會爭辯說,可以從一個完整專案裡一點一點地看單一類別或單一函數來學習,但在我看來,除非是最簡單的問題,大多數軟體內部都是相互依賴的。在不了解系統其餘部分的情況下,通常不可能理解一個特定函數或類別背後的設計想法和原則。
下一個問題是要從哪裡取得可以讀取的原始碼(當然,在此之前,你得能夠辨識哪些原始碼值得一讀)。優秀的軟體很多,既有開源軟體可以免費取得,也有閉源軟體需要授權。開源倉庫有譬如 Sourceforge 和 GitHub 。如果你在軟體開發公司工作,那麼你可以存取原始碼庫中的專有程式碼。第三種常見途徑是軟體開發書籍附帶的程序,或作為教育資源而提供的程序( Minix 是典型的例子)。確實,眾多的選項使我們難以抉擇,因此從茫茫程式碼世界中找出適合我們閱讀的是一項艱鉅而必不可少的任務。
另一個問題是程式所用的程式語言,讀他人的程式碼已經足夠困難了,如果同時還需要去熟悉一門夾雜著奇葩語法的新語言,它所帶來的負擔,在我看來簡直就是個會帶來極大挫敗感的災難。所以你需要找到用你熟悉的語言所寫的程式碼。但如果你要看的程式碼是來自書本上或作為教育資源所提供的,那懂不懂這門新語言並無關緊要,因為有導師可以解釋上下文。倘若你明知山有虎偏向虎山行,在沒有書或導師指引下,去閱讀一門並不熟悉的程式語言,那我建議你至少需要學習,並達到可以寫出自己的程式的程度(Hello World就不算了哈)。
前文有關上下文的問題使我想到了下一個問題,如果你不熟悉軟體本身,弄清楚程式碼在做什麼就困難得多。例如,如果你不是每天都在使用 Linux 並知曉 Linux 啟動順序,那麼就很難在看一邊 Linux 程式碼後弄清楚運行等級是什麼。使用某個軟體所獲得的經驗、知識能夠幫助我們更好地閱讀它的原始碼,這包括常用的術語、軟體的功能和特性,甚至包括你遇到的各種錯誤本身。
對我而言,我意識到 「閱讀原始碼」 並不能準確描述我所從事的活動,用 「理解原始碼」 來表述會更適合。對我來說,坐在筆記本螢幕前(或印成紙),只是單純地讀滿螢幕的程式碼是非常困難的。我需要程式碼之外其它的東西,例如我喜歡翻一翻文檔,玩一玩這個軟體,單步運行程式碼甚至寫測試程式碼去跑一跑,然後才能真正欣賞它。因為我會為此投入非常大的時間和精力,所以我必須精挑細選,尋找我要 「閱讀」(理解)的軟體。
我的第一層過濾是透過程式語言進行篩選,對我來說,我只閱讀由C#、VB.NET、Python 和Javascript 編寫而成的程式的程式碼(儘管我也熟悉C 、Ruby 和F#,但我並不認為自己有水平來理解其他人的程式碼)。接下來是尋找我使用過的軟體,這會讓我有種已經上車的感覺,因為我知道程式碼的意圖,以及它不能做的事情還有它的限制(如果我夠熟悉的話)。每天都在使用的開源軟體正是優秀的候選項(例如,我使用用C# 編寫的開源工具Cruise Control.NET、NANT 和NUnit)
碰巧我在一家軟體產品公司(一家微軟的公司)工作,所以我閱讀的源碼選擇項之一是我們公司在原始碼庫中的程式碼。如果碰巧你也在軟體公司工作,你可以查看其他的項目,甚至你著手專案的較早版本。這樣,除了可以獲得更深層的程式碼理解之外,你還可以很好地了解之前和之後都曾嘗試過哪些東西。不過有一些警告需要注意:
尋找文件齊全的專案(這適用於開源以及專有程式碼)。我的意思是說,這樣的文件應該突出整體設計,並說明程式碼背後的原理。如果只是簡單地自動生成的 Java Doc 類型文檔,則不能視之為我所描述的文檔 :-)。其中一種尋找途徑是利用為教育而創造的軟體(例如 Minix)。由於它們的目的是透過軟體進行教學,因此通常會有非常清晰的文件記錄下來,並且有大量資料解釋程式碼背後的設計原則。
那麼,現在你已經確定了要閱讀源碼的軟體並下載了它的源代碼和文檔,讓我們一步步閱讀並理解它:
「原始碼閱讀」在我看來,不僅僅是閱讀,它是一組獨特的活動,共同幫助人們理解程式碼。這似乎比簡單的 “閱讀程式碼” 更令人生畏,但它值得付出努力。
現在,你可以更輕鬆,快樂地「閱讀原始碼」了嗎?
#想了解更多程式設計學習,請關注php培訓欄位!
以上是初學者閱讀原始碼的方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!