1. 程式人生 > >學會閱讀原始碼後,我覺得自己better了

學會閱讀原始碼後,我覺得自己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。

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