0 前言
程序員給自己的職業(yè)生涯設定一個提升目標,“成為一個高薪程序員”不是一個簡單的目標。一方面,“我要變得更優(yōu)秀”意味著你知道“更優(yōu)秀”是什么樣的。另一方面,太多立志改善的人卻不知道怎么做。
下面我要分享8個可操作的,可提高編程技能的行為準則。
1 提醒自己得學習
學習的第一步是要認識到,你不懂。因為不懂,所以才需要學習。這聽上去很明顯,但有經(jīng)驗的程序員肯定記得自己用了多長時間才能做好這個心理建設。太多的計算機科學學生帶著一種傲慢畢業(yè):“我懂得最多”,自以為是地認為他們知道一切,并且有一種想要證明給每一個新同事看的強烈欲望。換句話說:這樣一種“我知道我懂我了解!”的態(tài)度會成為阻礙你學習新東西的攔路虎。
2 不要竭力證明自己是對的
要成就偉大——而不只是優(yōu)秀——你必須從經(jīng)驗中學習。但要小心,經(jīng)驗會讓我們重復錯誤的行為,養(yǎng)成壞習慣。我們都遇到過有著8年經(jīng)驗的程序員……不斷說自己的經(jīng)驗豐富,倚老賣老。為了避免一葉障目,你應該回顧自己所做的一切,問問自己,“怎樣才能做得更好?”
新手軟件開發(fā)人員(以及很多有經(jīng)驗的開發(fā)人員)觀看他們自己的代碼是為了欣賞它的精彩。他們編寫測試是為了證明其代碼可工作,而不是為了讓它失敗。真正偉大的程序員會積極尋找他們錯誤的地方——因為他們知道,最終用戶必將會發(fā)現(xiàn)他們遺漏的缺陷。
3 “代碼可工作”不是你止步的標志;而是你開始的地方
是的,第一步是寫出高質量的軟件,滿足規(guī)格說明。普通的程序員往往在這里就放棄了,直接跳到下一件事。
但是就此當作是“已經(jīng)完成”而止步,就像是拍了張照片就希望它成為一件藝術品一樣荒誕可笑。偉大的程序員知道第一次迭代就只是第一次迭代而已??梢怨ぷ鳌敲垂材?——但是這不是結束。你還需要讓代碼變得更好。
一些流程定義了何為“更好”。有沒有價值使其更快?文檔更簡單?更可重用?更可靠?對于不同的應用程序,這些問題的答案也各不相同,但是這個流程是不變的。
4 寫三遍
好的程序員編寫可工作的軟件。而那些偉大的程序員編寫的軟件運行起來極為出色。這很少是能夠一蹴而就的。最好的軟件通常要寫三次:
首先,你寫軟件是為了證明給自己(或客戶)看該解決方案是可能的。其他人可能不會意識到這僅僅是一個證明型的概念,但是你知道。
第二,讓它工作起來。
第三,讓它正確工作。
這種程度的工作可能并不明顯,如果你去看那些最佳開發(fā)人員的工作的話。他們做的一切都顯得如此才華橫溢,但你沒有看到的是,即使是明星開發(fā)者,在將自己的軟件展示給別人看之前,可能也扔掉過第一次和第二次的版本。拋棄代碼重新開始是一個能將“力求完美”納入個人工作流程的好方法。
如果不出意外,“寫三遍”會告訴你很多解決問題的方法。它可以避免你陷入困境。
5 閱讀代碼,閱讀很多代碼
你可能已經(jīng)聽過這個建議,實際上這是提高編程技巧最常見也是最有價值的建議。但是很多人不知道閱讀別人的代碼之所以如此重要的原因。
當你閱讀別人的代碼時,你要去看別人是如何解決問題的。但不要把它當作文學來看;把它當做一個教訓,一個挑戰(zhàn)。為了變得更好,你得問自己:
我會怎么寫那樣的代碼塊?在你看到另一種解決方法之后,你有什么不同的做法?
我學到了什么?怎么應用那個技術到我以前寫的代碼? (“我從來沒有想過在那里使用遞歸下降……”)。
我要如何改進這個代碼?如果它是一個開源項目,而且你相信自己有一個更好的解決方案,那么就去做!
用作者的風格寫代碼。練習這個可以幫助你了解寫軟件的那個人的思維。
不要光想不做。寫下你的答案,無論是在個人日記,博客,代碼審查過程中,還是在開發(fā)者社區(qū)論壇上。就像給朋友解釋問題可以幫助你理清解決方案,寫下并分享你的分析也可以幫助你了解為什么你對別人的代碼會有這樣一種既定方式的反應。這就是我前面提到的自省,自省可以幫助你冷靜地判斷自己的長處和短處。
警告:閱讀大量的代碼很容易,但要憑此就成為一個偉大的程序員未免異想天開。許多開發(fā)人員會通過開源代碼或其他軟件來“找尋答案”,而大多數(shù)人的做法是,復制和粘貼恰巧出現(xiàn)的可解決類似問題的代碼。這樣做實際上是在讓你變成一個更差的程序員,因為你只是盲目地接受別人的智慧,而沒有消化吸收。
6 寫代碼,而不僅僅是作為分配的任務
工作于個人編程項目有很多優(yōu)勢。首先,它提供了一個學習工具和技術的途徑,而這些工具和技術在你當前的工作中是學不到的,但是這能讓你在找下一份工作時更有競爭力。無論你是致力于開源項目,還是為當?shù)氐纳鐓^(qū)組織提供無償?shù)膭趧樱伎梢宰屇阍黾蛹夹g技能和自信。
為了好玩而寫代碼的另一個優(yōu)點是,它迫使你靠自己去搞清楚這些事情。你不能將難的那部分留給別人去做,所以它可以避免你太快地向別人尋求幫助。
小貼士:不要選擇那些你永遠不會失敗的個人項目。你需要失敗!但你不會希望在工作中失敗,或者當項目有時間期限的時候。
7 盡可能一對一地和其他開發(fā)人員合作
這有助于仔細傾聽別人的思路和想法。方法可以是結對編程,可以是去參加編程馬拉松,也可以是加入一個編程用戶群。當你致力于一個開源項目時,要注意你從用戶和其他開發(fā)人員那里得到的反饋。在他們的批評建議中有沒有什么共同點?
你或許會很幸運地找到一個可以信任的個人導師,他會指導你從編碼技術到職業(yè)決定的所有東西。不要浪費這些機會。
8 學習技術,而不是工具
編程語言、工具和方法變化不定。這就是為什么我們要積累盡可能多的經(jīng)驗,使用盡可能多的語言和框架。專注于編程基礎,因為基礎知識永遠不會改變:要更注重結構,而不是編程。如果你覺得只有一種做事的正確方法,那么可能是時候實戰(zhàn)檢驗了。教條會阻礙你學習新事物的能力,同時要試著讓自己慢慢適應變化。