年輕程序員的悲傷

jopen 9年前發布 | 18K 次閱讀 程序員

這是一個真實的故事,故事的主角是一位雖然年輕卻充滿了激情的程序員。那還是2004年底,他剛開始在一家小公司工作:一份不錯的薪水,使用的是他最愛的編程語言,能接觸到各種疑難雜癥,還可以做建模架構的工作。

對于這位年輕的開發人員,這并不是第一次工作經驗。但是他的第一個項目卻被證明是有問題的。那時候,他認為功能是不需要變的。但是他錯了,于是乎, 每個功能的改變都需要全部重構,從而導致bug橫行以及時間的巨大浪費。他甚至嘗試了一些良性的方法,如編寫測試。但是他的測試需要維護,需要編寫時間, 以及更多的時間才能被執行。

年輕程序員的悲傷

和每一個年輕的開發人員一樣,他的成長道路上都是那些經驗豐富的開發人員的聲音,“過早的優化是罪惡的根源!”,以及“寫測試!測試!測試!”。也 許他只是在重構一個小型的實用方法,但這個時候經驗豐富的開發人員過來了,鄭重其事嚴肅地警告他,“不是告訴過你不能過早的優化嗎?”,或者“你這是在寫 測試么?”。

但往往,年輕的開發人員直接就左耳朵進右耳朵就出了。因為他們不明白為什么過早的優化應該是罪惡的根源,以及為什么要寫好測試。從他以往有限的經驗來看,他認為接下來的技術指標并不能長效工作(因為它們往往會改變),以及寫測試純粹是浪費時間。

“到底是為什么我每次都需要重寫代碼?究竟又是為什么現在我寫的代碼之后還需要重構?還有就是到底是為什么我得花這么多的時間用來寫那些沒用的測試?“年輕的開發人員心里在咆哮。

于是乎,終于有一天,年輕的開發人員又開工了一個新項目。這一次,他決定無視那些經驗豐富的開發人員的警告:他相信他寫的每一個代碼片段都會既快捷、可配置,又強大,并且可以承受每一次參數規格的改變。

在他絞盡腦汁地搞定項目的核心之后,年輕的開發人員忍不住得瑟起來:“哈哈,我就說那些‘老家伙’的話是錯的!”仿佛凱旋在望,年輕的開發人員眼中已經出現了勝利的光芒。

然而,發布一段時間之后……

突然有一天,客戶告知他們程序發現了bug。經驗豐富的開發人員看了這個bug,找到問題的所在,就要求年輕的開發人員去修復他自己造成的bug。

聽到自己的代碼被嫌棄了,年輕的開發人員第一感覺是生氣。但是當看了項目之后……卻發現,他居然無法理解自己寫的代碼了!他已經完全看不懂這些代碼的含義!天哪,嗚呼哀哉!

但是沒辦法,這是他的問題,他也只能硬著頭皮上,好了,終于修復好了這個bug——但是過幾天又出現了新的bug。bug——補丁,bug——補丁,焦頭爛額。

年輕的開發人員簡直要崩潰了,“也許我并不適合這種工作,不然我的代碼怎么總也寫不好?”在各種質疑自己的聲音中,年輕的開發人員半信半疑地打開了經驗豐富的開發人員的項目。

他震驚了!代碼是如此簡單易懂——有注釋、有測試。這跟他寫的代碼完全有著本質的不同。特別明顯的區別就是:沒有額外的配置,對每一行代碼都進行了測試,每一個方法都有一個有意義的名字,并且方法非常短(最長的也只有幾十行代碼),代碼只做了客戶要求做的事情。

在那一刻,年輕的開發人員是非常沮喪的,但是經驗豐富的開發人員來了,他走到年輕的開發人員的身邊,一邊走他其實一邊已經在開始考慮如何重構這些錯誤的代碼。

在一起合作解決問題的時間里,年輕的開發人員目睹了經驗豐富的開發人員一步步解決問題的過程;有時候經驗豐富的開發人員還會監督年輕的開發人員編寫代碼。

幾天以后,又一次發布標志著bug已經被修復了。造成bug的那部分代碼片段現在已經進行了測試,不但易于閱讀,并且非常穩定。經驗豐富的開發人員看著年輕的開發人員,問:“你現在應該明白了吧?”

年輕的開發人員點點頭。現在他確實明白了。想要完美,其關鍵并不是能夠預測未來,而是編寫易于改變并經過測試的代碼(這樣,如果要改變代碼的話才不 會造成bug),而且只需要滿足當前的需求。而當他意識到這一點的時候,他在無形之中,已經蛻變成為了“差不多”經驗豐富的開發人員。

“我們現在要重構整個項目嗎?”年輕的開發人員問。

“當然不!這又沒有預算的。”經驗豐富的開發人員斬釘截鐵地回答。

“但是,要是出現其他bug怎么辦?”年輕的開發人員問。

“可以讓自由職業者來解決那些問題。”經驗豐富的開發人員答復。

然后,“差不多”經驗豐富的開發人員開始能寫出優良的代碼,漸漸地向更高層次的水平靠近。當然,這是另一個故事了。

對于年輕的開發人員的建議:請回過頭去看看你曾經寫的代碼,如果你的代碼現在看上去沒有以前感覺的那么漂亮,那么說明你在進步。

對于經驗豐富的開發人員的建議:當你的身邊出現了一個年輕的開發人員,或許你需要不時地替他們收拾爛攤子。如果你想擺脫這樣的處境,那么就讓他們盡快學會編寫得體的代碼。

對于自由職業者的建議:你或許應該提高你的酬勞了:-P

譯文鏈接:http://www.codeceo.com/article/the-sorrows-of-young-developer.html
英文原文:The Sorrows of Young Developer
翻譯作者:碼農網 – 小峰

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!