天天看點

學會閱讀源碼後,我覺得自己better了

我有一個大學同學,名叫石磊,我在之前的文章裡提到過幾次,我們倆合作過很多項目。隻要有他在,我就特别放心,因為幾乎所有難搞的問題,到他這,都能夠巧妙地化解。他給我印象最深刻的一句話就是,“有啥解決不了的?隻要你肯閱讀源碼。”

說起來源碼,我是不太建議新手去閱讀,容易勸退。不信,你讓一個國小生去讀一下《百年孤獨》,我保證他會從此對閱讀失去興趣。去年,我忍着頭皮讀了這本書的前十頁,然後就沒有然後了——讀不下去。我覺得自己還是嫩了點,生活閱曆沒到那個層次,感悟、内化、思考的能力也沒到那個份上。

我建議程式員至少在有一到兩年程式設計經驗後,再去閱讀源碼,這個時間段會比較合适。我是大三出去實習的,那會的水準真不敢恭維。不過,公司對我們的耐心還是有的。二十多名新人,分兩組,一組做個電腦,一組做畫圖工具,要求兩個月内完成。

說白了,就是考核我們的,不合格就請退。我做的是電腦,成品後來放到了 CSDN 的資源庫上,騙了不少 C 币。坦白說吧,有一部分代碼我是從網上複制粘貼的。

就這部分代碼,我研究了一個多月時間,硬是沒有吃透,隻是說把其中的一些小 bug 修複了——靠着這種能力,我謀得了一份可以掙錢養活自己的差事。

接下來一年半的工作時間裡,我沒有強逼自己去閱讀源碼,而是跟着項目組的進度,不斷地積攢程式設計的經驗。就像小孩子一樣,在會跑之前,總得先學會走路啊。

時間來到了 2012 年,我通過某些契機了解到公司以後的發展重心會是 Flex(結合了 B/S 與 C/S 技術優點的新一代富用戶端技術),我就開始在項目間隙研究起了 Flex 的源碼。這時候,我覺得自己“複制粘貼”(或者說面向搜尋引擎)的能力已經爐火純青了,平常的工作任務都能夠應付,但總覺得自己還很菜。

Flex 的整體架構是日方人員設計的,在原生的技術上做了一層封裝,元件更豐富了,有點類似于現在前端非常火熱的 Vue.js 或者 React。

我當時還沒有參與到 Flex 的項目當中,但因為和公司的一個前輩關系比較要好,就找他要了一個小項目的源碼,在本地搭了一個調試環境,開始“打怪更新”了。

不得不承認,日方開發人員寫的代碼還是非常嚴謹的,注釋比代碼多得多。我的日語水準雖然不咋滴,但在翻譯軟體的幫助下,再加上對代碼的感覺能力,還是能夠鑽研下去的。

這裡順帶透露一點。有兩個源碼的作者來過蘇州的分公司,我見過他們,年紀至少在四十歲以上,據同僚說,有一個都五十多歲了,看來保養的不錯啊。他們為人非常謙和(學到了我們民族的精髓),完完全全是一副純粹的技術人的模樣——那些大齡程式員都去哪了?答案就在這裡,隻要你技術夠牛,公司就需要你。

經過四個多月不懈的努力,我覺得自己的程式設計能力得到了飛速的提升,不僅會用架構已有的元件,在必要的時候還能夠擴充一些自定義的元件——因為我已經讀懂了大部分的源碼,敢在上面動手動腳了。

在這期間,我用 Flex 做了一款聊天工具,我在很早之前的文章裡提到過。公司内部使用的 spark 聊天工具是有檔案記錄的,不能在上面談一些工作之外的話題,比如說有幾個同僚喜歡分享魔獸世界的心得體會,我這個工具恰好為他們提供了便利,伺服器就在我本地電腦上。

就是憑借這款聊天工具,我被一個上司看中了,直接挖我過去做了小組長,負責項目的編碼部分。更重要的是,加薪了!

是以說,我一直覺得,閱讀源碼是一項重要的能力——它能夠讓你從一名代碼的搬磚勞工蛻變成為一名會造輪子的工程師。

我現在八年工作經驗了,但前幾年出來的時候沒注重基礎,沒研究過源碼,現在三十了,感覺壓力上來了。投了很多履歷,也沒啥面試的消息。

上面這段話是前天一名讀者安少給我發的資訊,看完後,真的蠻為他感到惋惜的。閱讀源碼雖然不是萬能的,但對一個程式員的能力提升,真的是非常重要,大概就相當于内功心法吧。

如果安少在程式生涯的早期(三五年的時候)就能夠靜下心去源碼裡“潛水”或者“暢遊”一段時間,他就不至于在 30 歲的時候擔心自己的前途。

參加過 Java 崗位面試的讀者應該清楚,面試官喜歡問一些關于源碼方面的知識點,比如說,“HashMap 的底層原理是什麼?大小超過了負載因子定義的容量該怎麼辦?”如果平常肯去倒騰源碼的話,這些問題你肯定能夠答得行雲流水,否則真的是一臉懵逼啊。

總結一下,閱讀源碼不僅能夠提升你的程式設計能力,還能夠讓你從容面對面試官的提問。對了,我差點忘記一點,閱讀源碼還是解決 bug 的銀彈。

這也是為什麼 GitHub 這麼流行的原因之一啊,因為它上面的源碼都是開源的。這就意味着,如果程式出現了故障,而故障的原因是由這些源碼引起的,你就不必苦苦等待源碼的作者去修複它,“自己動手豐衣足食”啊。畢竟源碼的作者還有很多其他重要的事情要做,他不可能線上等你 issue 啊。

還記得我在文章開頭提到的石磊吧,他遇到問題的第一反應就是去把源碼的底褲扒個精光。在他眼裡,問題發生的根源要麼是他自己,要麼就是源碼,是以我一直覺得他蠻有極客精神的。

而我,通常是,先檢查自己的代碼,如果找不出,去求助一下搜尋引擎,如果還找不出,才會去閱讀源碼。

不要怕,一開始閱讀源碼真的會有點難度,但如果你想要成長,就不能一直待在自己的舒适區,你得硬着頭皮上。等你頭硬(秃)了之後,就真的變強了!

如果覺得文章對你有點幫助,請微信搜尋「 沉默王二 」第一時間閱讀。

本文已收錄 GitHub,傳送門~ ,裡面更有大廠面試完整考點,歡迎 Star。

我是沉默王二,一枚有顔值卻靠才華苟且的程式員。關注即可提升學習效率,别忘了三連啊,點贊、收藏、留言,我不挑,嘻嘻。