優(yōu)秀程序員因何而優(yōu)秀?
這些年我曾和很多程序員一起工作,他們之中的一些人非常厲害,而另一些人顯得平庸。不久前因為和一些技術(shù)非常熟練的程序員工作感覺很愉快,我花了一些時間在考慮我佩服他們什么呢?什么原因讓優(yōu)秀的程序員那么優(yōu)秀,糟糕的程序員那么糟糕?簡而言之,什么原因成就了一位優(yōu)秀的程序員呢?
根據(jù)我的經(jīng)驗,成為一個優(yōu)秀程序員同年齡,教育程度,還有和你賺多少錢沒有任何關(guān)系。關(guān)鍵在于你的做法,更深入地說,就是你的想法。我注意到我所欽佩的程序員都有一些相似習(xí)慣。不是他們所選語言的知識,也不是對數(shù)據(jù)結(jié)構(gòu)和算法的深入理解,甚至不是多年的工作經(jīng)驗。而是他們的溝通方式,他們管理自己的方式,以及以他們精湛技術(shù)水平編程演講的方式。
當(dāng)然成為一個優(yōu)秀的程序員還要具備更多特質(zhì),我也不能單單依靠是否存在(或者缺少)這些特質(zhì)來評判一個程序員。但是我知道當(dāng)我看見它,當(dāng)我看見一個程序員具備這些特質(zhì)的時候,我認為,“這個人真的知道他們正在做什么”。
優(yōu)秀程序員做調(diào)查研究
或者叫“三思而后行”,或者叫“谷歌一下”
不論你怎么稱呼它,大多數(shù)可能會遇到的編程問題已經(jīng)以某種形式解決,傳道書早就記載著世界上本來就沒有什么新鮮事。優(yōu)秀的程序員在解決問題之前知道通過GitHub圖書館、網(wǎng)絡(luò)博客,或者通過與經(jīng)驗豐富的程序員交流等形式來做調(diào)查研究。
我見過甚至是優(yōu)秀的程序員可以快速找出解決方案,但是和我一起工作過的糟糕的程序員從來不求助于他人,結(jié)果做了大量的重復(fù)工作或者錯誤地解決問題,不幸的是,后來他們終將為自己犯下的錯誤付出了代價。
優(yōu)秀程序員閱讀錯誤信息(并按照它們行事)
這包括解析堆棧路徑信息。是的,這是一件非常丑陋不幸的事情。但是如果你不愿意這么做的話,你怎么才能知道哪里錯了呢?我知道的高效程序員是不會害怕深究問題的。低效的程序員看見有錯誤,但就是不愿意甚至是去讀這些錯誤信息。(這聽起來很可笑,但你會驚訝我遇到它的頻率)
更進一步地說,優(yōu)秀的程序員發(fā)現(xiàn)問題馬上就解決它。讀錯誤信息對他們來說僅僅是個開始,他們渴望深究問題并查出問題的根源。他們不喜歡推卸責(zé)任,而是愿意查找解決問題的方案,問題在他們這里止步。
優(yōu)秀程序員看源代碼
文檔、測試、團隊,這些都會說謊。盡管不是故意的,但是如果你想確切地知道事情是怎么回事,你必須自己親自看源代碼。
如果它不是你最擅長的語言,你也不要害怕。如果你是一個Ruby的程序員,你懷疑在Ruby的C語言庫中有個錯誤,破解打開看看。是的,你可能拿不到源代碼,但是誰知道呢?你只是可能而已,你有更好的機會,總比你根本不去嘗試好吧。
不幸的是,如果你處在一個封閉源代碼的環(huán)境中,這會變得非常難,但道理是不變的。糟糕的程序員對于查看源代碼沒有絲毫的興趣,結(jié)果問題困擾他們時間,要比愿意看源代碼的時間長得多。
優(yōu)秀程序員說干就干
優(yōu)秀的程序員趨向于主動去做。他們的內(nèi)心有著難以控制的沖動,當(dāng)他們確定問題或者發(fā)現(xiàn)新的需求時他們立刻會實現(xiàn)解決方案,有時過早有時太過激進。但是他們對問題本能的反應(yīng)是正面解決問題。
有時這會令人很煩惱,但是他們的熱情是他們做好事情的一個重要部分。一些人可能拖延時間回避問題或者等待問題自己能夠消失,然而優(yōu)秀的程序員一開始就解決它。簡而言之(或者顯而易見),如果你看見有人興致勃勃地查找問題并在解決,很可能你的手下有位優(yōu)秀的程序員。
優(yōu)秀程序員不逃避困難
這通常是糟糕程序員的特點:他們輕易地從一個問題跳到另一個問題,在沒有真正理解一個問題之前就進入到下一個問題。他們會把責(zé)任歸咎于程序的錯誤,然后花費大把的時間調(diào)試已經(jīng)運行良好的代碼。他們讓情感占據(jù)主動,相信直覺,而不是仔細嚴謹?shù)姆治觥?br />
如果你匆匆忙忙地解決一個問題,甚至視每一個問題為震驚世界的災(zāi)難。你很可能犯錯誤或者沒有解決潛在的問題。優(yōu)秀的程序員花時間去了解發(fā)生了什么錯誤,哪怕災(zāi)難來臨的時候;但更重要的是,他們對待平常的問題像是要解決的重要問題,因此他們更準(zhǔn)確地解決更多的問題,并且這樣做沒有提高團隊的緊張程度。
優(yōu)秀程序員善于溝通交流
說到底,編程是一種形式的溝通交流。寫代碼和寫散文創(chuàng)作一樣,能夠簡潔地表達你的想法很重要。我發(fā)現(xiàn)那些可以寫簡潔郵件,優(yōu)雅的狀態(tài)報告,或者甚至只是一個有效的備忘錄的程序員也將會是優(yōu)秀的程序員。
這能應(yīng)用在寫代碼還有英語上。用圓括號、括號和單個字母的函數(shù)寫出一行代碼當(dāng)然是有可能的,但是如果沒有人理解它,有什么意義呢。優(yōu)秀的程序員會花時間以各種渠道交流他們的想法。
優(yōu)秀程序員激情四射
我認為這可能是優(yōu)秀的程序員最重要的方面(也許這點也適用于除計算機科學(xué)領(lǐng)域的其它領(lǐng)域)
如果你真的在乎你所做的事情,如果不把它當(dāng)成工作,當(dāng)作一個業(yè)余愛好、興趣或一件很有吸引力的事情,那么在該領(lǐng)域你比其他人更有優(yōu)勢。優(yōu)秀的程序員一直不斷編程。普通程序員一天工作八小時,并且沒有業(yè)余項目,也沒興趣回饋社區(qū)。他們不會不斷地嘗試新方法,而只是為了看看它們是如何運行而執(zhí)著于編程語言。
當(dāng)我看見一個程序員利用周末的時間做自己喜歡的項目時,參與創(chuàng)作他們每天能用到的工具時,執(zhí)著于新的有意義的事情時:那個時候我確信我眼前的是一個令人驚奇的人。***,優(yōu)秀的程序員視他們的職業(yè)不僅僅是賺錢的途徑,更是讓生活變得有些不同的方法。我認為那就是成就***秀程序員的真正原因。對于他們來說,編寫代碼是改變世界的一種方法,也是我非常尊敬崇拜他們的原因。