如何閱讀和學習別人寫的Android程式程式碼
程式碼閱讀技巧提高編寫程式碼的能力。
1.執行程式碼——是的,這是閱讀程式碼的第一步。這可能不會給你過多關於專案的細節,但是,你將知道如何構建它並執行它,你將瞭解它使用的庫、它所依賴的開發框架等等,這是提高你對某個特定專案理解的好方法。如果你想編寫與你正在探究的特定專案類似的自己的軟體,你可能會對你應該使用的框架或庫有一些想法。
2.找到高層次的邏輯——當你開始閱讀一個專案的程式碼時,你可能會陷入到每一個細節當中。這是有問題的,相反的,你應該專注於高層次的結構。要找到切入點,並從那裡開始,大部分的軟體專案都有一個主要的方法,就從那裡開始。此外,如果這是一個web應用程式,請開始檢視不同的包,比如業務邏輯存放在何處、UI程式碼儲存在哪裡、控制器在何處等等。大致來說,就是瀏覽整個專案並獲得一個基本的想法,然後問自己想專注於什麼地方,就先從那個部分讀起。你可以不讀完整的程式碼庫,而只是讀它可能會引起你興趣的一部分。當你找到你的切入點,你可以通過方法呼叫,看它引領你到何處,從而瞭解專案的業務邏輯。
3.使用/瞭解工具——有很多工具可以用來閱讀和探究原始碼,有助於視覺化程式碼。例如,IntelliJIdea工具具有導航原始碼的功能,允許你通過單詞、單詞的一部分,甚至是單詞的縮寫來搜尋。你也應該學習鍵盤快捷鍵。用滑鼠導航原始碼可能會相當枯燥和緩慢,用鍵盤快捷鍵可以更快地跳轉。你可以快速地從原始碼的一部分跳轉到另外一部分。
還有一個閱讀程式碼的好軟體,叫Sourcegraph,這是由兩個斯坦福大學的畢業生建立的,他們是Quinn Slack 和 Beyang Liu,他們在花費時間去檢視缺少文件說明的程式碼以後,決定開發一個工具來幫助他們更好地閱讀和理解程式碼。
4.瞭解語言/約定——深入瞭解某個特定語言有助於提高程式碼閱讀技能。每種語言都有自己的一套約定、樣式和語法。這些知識幫助你快速地熟悉一個特定的程式碼。例如,在java語言中,方法名以小寫字母開頭,而在C#語言中,方法名以一個大寫字母開頭。知道這個區別可以幫助你從原始碼中識別方法。
5.閱讀最佳實踐/設計模式——你正在閱讀的程式碼,或者它的某個結構,可能看起來很晦澀,或者你可能不熟悉它,這是很自然的。有許多良好的實踐和設計模式,人們用它來正確地和最佳地做事。例如,有一種模式稱為Singleton,它的建構函式保持私有。你可能會問,究竟為什麼有人想保持建構函式私有呢。我一直認為它是公有的,否則,我如何建立一個類的例項。嗯,這背後有一個原因。Singleton模式防止你不止一次地例項化一個類,其中有許多實際的應用案例。如果你瞭解這種模式,你就不會為此而頭撞南牆了。因此,對於某些模式的瞭解,例如,Gang of Four(Erich Gamma, Richard Helm, Ralph Johnson,John Vlissides軟體設計領域的四位世界頂級大師.)有23種有文件說明的設計模式,可以顯著地幫助你提高程式碼閱讀能力。
6.程式碼審查——軟體開發是一個非常講究協作的工作。沒有人可以單獨構建一個大型的或重要的軟體。每個軟體都是由一個團隊構建的。在一個團隊中,每個人都貢獻自己的一份力量去塑造這個專案。在專案結束的那一天,每個人的貢獻都會合併成一份對使用者真正有價值的工作。除了做實際的編碼以外,現在每一個團隊都有另外一種做法,那就是在進行觀察、建議和相互學習時,互相審查對方的程式碼。這是一個構建程式碼庫知識的強有力的工具,在團隊中建立牢固的紐帶,提高程式碼質量,從而減少系統中的錯誤,並使客戶滿意。
做程式碼檢查,你不得不閱讀團隊中其他人的程式碼,最終會提高你的程式碼閱讀能力。
7.臨時重構——臨時重構也可以幫助您提高程式碼閱讀技能。你可以找取一段長的方法程式碼,然後不斷地把方法細分成多個部分。持續分解,直到你瞭解這一大段方法程式碼背後真正的意義。之後,你可以對這些方法做些註釋,然後回滾這些更改。
這可以幫助你理解方法的架構,也可以增加你程式碼重構的知識。
也有人這麼說:
完整的專案一般會有比較嚴謹的分包,每個包一個功能。包下又會分子包,將檢視/實體/控制等等部分分開。如果這樣按包看,可以從實體類和工具類看起,實體類沒有邏輯比較好懂,工具類看不懂自己呼叫試試也差不多知道了。然後看控制層,控制層方法功能一般比較單純,方法邏輯先放著不管,搞懂功能再說。然後看介面,基本上就通了。比較重要的是邊看要邊加註釋,越詳細越好。細到每個變數是做什麼的,每個if else分支是在什麼情況下觸發的,看懂的都要註釋,以後看也方便。