您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關如何看待看源代碼,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
1. 前言
很多人問我如何看源代碼?是不是我在看源代碼這方面特別有天賦?
其實不是的,我也只是個普通人,跟大伙沒啥分別,
只不過我沒有別的特別愛好,一有空時,不是寫自己的代碼就是看別人的代碼,
我在看源代碼時比較有耐心,純粹就是興趣驅動,或者說是一種好奇心。
當然,我不會隨隨便便拿起一個開源項目就看,而是經過一定了解后才決定看它的源代碼的,
一旦決定要看了,我至少要把這個開源項目80%以上的代碼看完,并不是那種膚淺的看,
而是仔細研究每一行代碼。
2. 我看過這些開源項目
按時間先后順序:
2007:
OpenJDK Javac1.7
2008:
Erlang編譯器 (看得最少的一個,只看了一半源代碼)
2009:
Tomcat6
Junit4
Ibatis2.3
OSCache2.4
Ehcache1.6
Mongodb-mongo-java-driver1.2
Velocity1.6
2010:
MySQL JDBC Driver (mysql-connector-java-5.1.13)
PostgreSQL JDBC Driver (postgresql-jdbc-8.4-701)
Netty3.2
Tomcat7
2011:
Jetty8
目前主要關注這4個:
OpenJDK Javac1.7
Netty4.0
Tomcat7
Jetty8
我現在每隔1到7天就會看這4個開源項目的源代碼庫中有沒有更新,
我裝了TortoiseHg, TortoiseGit, TortoiseSVN,
因為看Javac1.7的源代碼更新用TortoiseHg比較方便,
而看Netty4.0要用TortoiseGit,最后兩者用TortoiseSVN。
3. 我對看源代碼的人進行了分類
分5種人:
1) 解決問題型
這種類型的人通常是在工作學習中碰到了一個很費解或很棘手的問題,
文檔也看了,google也找了,同事、同學也問過了,
但是問題還是無法解決,于是不得不把源代碼下下來,然后一邊看一邊debug,直到問題解決。
2) 三分鐘熱度型
可能是看到別人也在看或者在論壇上看到某些人說XXX設計得很好,性能也不錯,或者看到某些人在論壇上發了些分析源代碼的文章,
再加上自己一開始也興趣滿滿,然后也跟風了,看了10來個類的代碼,啊,發現太痛苦,方法之間調來調去的,太繞了,頭快炸了,
給自己找個理由,這代碼寫得太垃圾了,媽的,不看了。
3) 一知半解型
網上經常看到有人在寫分析源代碼的文章,一上來就是一陀陀的源代碼,然后告訴你這做了什么,那做了什么,
就加了點中文注釋,有時這中文注釋還不如源代碼中的英文注釋好理解,然后過了一段時間,發現文章不更新了,也沒有后續了。
4) 真才實學型
像原作者一樣思考,能輕松說出此開源項目的核心架構,精確理解80%以上的源代碼,能找出bug并能提交相應patch,
5) 創新型
對此開源項目的優缺點了然于心,能夠提取其精華為我所用,想出更好的方案解決現有問題,超越原作者。
4. 我看源代碼的經驗
僅供參考,不要隨意模仿,每個人都應該找到適合自己的方式,
唯一重要的是以下3點:
1) 時間
最好能有一大段時間集中精力去看,比如你要看Tomcat7,要有3個月的時間每天花3到8小時去不停的看,
時間拖拉得越久,會看了前面忘了后面。
2) 興趣
看代碼不要有任何功利性,你要對它有興趣,充滿好奇心,去理解它做了什么,怎么做的。
3) 耐心
這一點說起來容易,真正要做到是極其困難的,比如當你某些類連看了三次時還看不懂,不要先想別人寫的代碼是否垃圾,
先想想你在這方面的背景知識是否足夠,比如在看Tomcat實現http協議相關的代碼時,一邊看代碼一邊看http協議是最有效的方式,
再比如你想看編譯器相關的代碼,最起碼在看之前,你要對<<編譯原理>>這門課中的內容有基本的了解。
如果背景知識有了還看不懂怎么辦,看不懂的代碼先放下,有些if分支只有你把整個項目都大致了解了一下后才能理解的,
要反復的看,看三次僅僅是個入門級別。
先簡單說一下我的經歷:
小學到初中我還算是個好學生,在班里經常拿第一,
但是從小學6年級到初三這4年比較特殊,遇到了一個很垃圾很垃圾很垃圾的數學老師,
所以這4年我的數學基本上就是自學的了,我的自學能力從小到現在都是非常的強。
當然,這不能歸功于這位垃圾老師,我自小就很叛逆,不喜歡這禽獸的教學方式,沒有此垃圾,也許我的生活會是另一番景色。
我不像正常人那樣上完初中上高中,然后再上大學,
而是上完初中后就直接到一所師范大學上中專+自考大專,2001年就畢業了。
中專是學會計統計類的,自考大專是計算機應用,大專一共才12門課,沒有英語,數學方面只有高數,而且還是第一冊,
核心專業課方面只有pascal、c、8086匯編語言、FoxPro、模擬電路、數據結構、操作系統、軟件工程、計算機接口與技術。
只要不是硬件類的專業課程我就學得非常好,硬件類課程就只是聽老師講,當時連硬盤長什么樣都不知道。
我2001年畢業時才19歲,然后就出來找工作了,說這些只是想說我從學校得到的教育并不多,
現在回想起來從學校學的C語言、匯編語言、數據結構、操作系統為我以后的自學提供了一些幫助。
直到2006年,我辭職了,之前我己經工作了4年,都只是做應用軟件項目,
所以數學基本上沒用過,英語也用得少之又少,英語其實比現在的高中生水平還差,
所以要看英文的技術文章也是看不懂的。
2006年我本來是要復習考研究生的,我從3月份開始連背了三個月的英語,每天花4到8小時背新概念英語的課文,
一、二冊全部背完,第三冊背了前42課,第四冊背了前10課,我以為這樣的水平足夠應付考研英語了,結果拿試卷一做,
閱讀理解至少有2/5的單詞認不得,不得不去背考研英語的單詞。
數學基本上忘光了,到網上下初中和高中的新課標課本下來看,
高數、線性代數、概論全都自學,還買了相關的數學書來看(像幾何、離散數學等等)。
天天做那些垃圾數學題,還要背馬哲、毛概,專業課倒是小兒科。
一直到10月份,各校出來招生簡章了,想報10大高校,結果別人不鳥你專科生,你專科生沒有報名資格,
好吧,換二線的可以了吧,結果還是差不多,不是要本科,就是要發表啥論文才能報,
最后,很不情愿的報了個很平庸的所謂211大學。
此后越發覺得天天做題背單詞背書實在是件極其無聊的事,再加上報考這件事,嚴重打擊積極性,一直想放棄考研但是又一直堅持著,
直到11月23日,那天去書店看書,翻到一本講編譯器實現的書,
也就是所謂的"虎書",當時并不知道編譯器是什么,因為我在學校時沒學過編譯原理,在書店連看了一小時,覺得很有趣,
就買了回來,接著就把考研的書全丟到一個角落里了。
接下來你應該懂的,我瘋狂的買書,"龍書","鯨書"啥的我都買了,只要是有關編譯器的,不管是國內還是國外我都買,
因為我并不是一看就全懂的,也是因為"虎書"剛開始一兩章還好理解,后面的我當時就看不懂了,
我有個習慣,就是實在看不懂的書,我就會換一本,確認一下是我自己的原因還是書本身的問題,
現在我只會說"虎書"翻譯得并不好,"龍書"更好理解,當然一開始就看"龍書"也并不是那么好理解,
所以我當時甚至連形式語言和自動機相關的書我都買來看了。
我連看了3個多月,當時覺得看書不過癮,就想找個實際的編譯器來玩,
我下了GCC和LCC,當時剛好sun公司又把javac開源了。
因為工作中只用到php和java,c語言已經4年沒用過了,加上javac比前兩者要小很多,
所以從2007年二月份開始第一次看javac的源代碼,也是第一次看別人的源代碼。
javac的源代碼不多,8萬行都不到,花了我3個月的時間,平均每天至少花7小時看代碼。
因為我當時只會java1.4,java1.5之后出來的很多東西都不懂,所以也是一邊看javac的源代碼一邊學新語法。
2007年5月份時我還在JavaEye上發了第一篇有關javac的文章,得了個精華,引起了一點小轟動,
這里有證據: http://www.iteye.com/topic/84833
內容貌似當年被我刪除了,想不起來是什么原因了,zhh3007就是我本人以前的id。
當時看代碼的方法是非常原始的,但是直到現在我還在用這種方法,只不過現在有時會用eclipse來看,
我是這么做的:
看原代碼用 EditPlus,
找到第一個入口類: com\\sun\\tools\\javac\\Main
自己再寫一個Debug類,按執行流程看到一個方法時,就加入類似下面的代碼塊:
public static int compile(String[] args) { try {//我加上的 DEBUG.P(Main.class,"compile(1)"); DEBUG.PA("args", args); com.sun.tools.javac.main.Main compiler = new com.sun.tools.javac.main.Main("javac"); return compiler.compile(args); }finally{//我加上的 DEBUG.P(0,Main.class,"compile(1)"); } }
然后一定要重編譯源代碼,再運行,保證自己加的代碼被執行到了,我會把輸出的debug結果重定向到一個文件中,
然后一邊看源代碼一邊看輸出結果,一些變量或表達式自己想看結果也會加DEBUG.P(...),
碰到一些代碼行數很多的類,我甚至會把每個方法copy出來放到一個新的java文件中,
然后打開多個EditPlus,每個EditPlus看一個方法,而且是按照方法的調用順序打開EditPlus看的。
可能看到這很多人會覺得這種方式好土,我也不能說好不好,從今年開始,因為我的電腦裝了Eclipse了,
所以Jetty8的源代碼我是用Eclipse看的,也不再打DEBUG輸出,也不再copy方法,而是直接用eclipse的debug跟蹤功能,
但是我現在提出質疑了,Jetty8的代碼量只是Tomcat6的1/3,我用Eclipse這種方式來研究源代碼并不能節省我的總時間,
我用最原始的方式研究Tomcat6也只花了3個月,現在研究Jetty8已經用了我兩個月的時間,而且看Tomcat6和Jetty8是兩個類似的東西,
按理說先看Tomcat6后看Jetty8應該花的時間更少才對。
我總結了一下,為什么最初的方式好,那是因為我那樣不斷折騰源代碼的過程中已經間接讓我記住了代碼的布局,
我在敲那些重復的DEBUG.P代碼時我把局部變量、表達式、字段都輸出了一次,這有助于我的記憶。
而Eclipse的debug功能只是在不停的按F5-F6-F7-F8,打斷點,方法調用太深時很難理清前后關系,
有時看了一星期,連哪個類在哪個目錄都不知道,因為debug時,跟到相關的類eclipse會自動打開那個類,不用你從目錄中找。
Eclipse的代碼折疊粒度又不能折疊到塊級別,不能折疊if、while,一旦方法的行數很多,看起來會很累,分不清這個方法的層次結構,
而EditPlus在看方法時就看得很舒服,因為他能折疊if、while,看完了一個while我可以把他折疊起來,
有多個if-else時只要折疊一下就不會超過一屏。
你能打開20個EditPlus,但是你不能同時打開10個Eclipse,除非你電腦的內存牛X到不行。
有一點很重要,不管是哪一種方式,一定要把環境搭建好,你自已要能夠編譯源代碼,并且多寫些例子去驗證源代碼中的執行流程,
我一般不會去看源有代碼中的例子或測試用例的,只有想不出時才去看(特別是看編譯器時,一些用例你很難想到)。
我為什么要看這么多源代碼?
除了個人興趣之外,現在想起來其實還有個很好笑的原因:
2007下半年和2008一整年,這段時間很多人說Java快死了,Ruby/Rails、Erlang很火,
我經常上JavaEye,免不了也受影響,所以在2008年時還學習了Ruby/Rails、Erlang,連Erlang的編譯器都玩了一下,
之后發現并不是那樣滴,只不過是一些大佬在鼓吹而已,再加上2008年家里出了點事,所以過得很郁悶,
一有閑情就跟JavaEye的大佬們"打架",想來也是種樂趣,算是種排解壓力的方式。
當然,與此同時,也會從技術的角度思考Java出了什么問題,所以從2009年開始就專心研究技術了,還把douyu的原型鼓搗出來了。
2009年研究的那些開源項目其實都是很順其自然的事,我要做一個http服務器,Tomcat已經做好了,我想知道他怎么做的,
我就去看,看這些項目就是為了想知道他們做了什么,怎么做的,哪里做得不好,我能不能比他們做得更好。
現在,看代碼已經是我的一種習慣了,從畢業那年到2008年我買了幾萬塊錢的書,以至于我來杭州后都沒有把桂林的房子退了,
因為書多,桂林那房子除了回去能住個幾天外,現在是租給書住的了。
從2009年到現在,兩年多時間我沒有再買書,都是看源代碼學新東西,
如果是一個全新的領域,最多也就是在網上找點入門資料,然后再看源代碼,
包括下半年我準備研究HotSpot,已經是C/C++的領域了,我沒有任何學習壓力,只是一個時間問題。
一個人的自我學習能力非常的重要,Java相關的和Java之外的所有東西我都是自學的,
我沒有特別問過什么人,也沒參加過培訓,實在不懂的地方就查資料買書看。
如果看代碼看不懂,這幾點一定要明白:
1) 相關背景知識是否具備
2) 要有耐心,多看幾遍
3) 不要指望別人告訴你答案,別人沒跟你說也不要說別人高高在上不理你,因為這不是別人的義務
4) 經過對比之后再說別人的代碼爛
以上就是如何看待看源代碼,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。