與你所相信的恰恰相反,單純地每天埋頭于工作并不能算是真正意義上的鍛煉——參加會(huì)議并不能鍛煉你的人際交往能力叔营;回復(fù)郵件并不能提高你的打字水平有巧。你必須定期留出時(shí)間,集中鍛煉芬膝,這樣才能把事情做得更好望门。
這是一個(gè)重要的區(qū)別——我每天都開(kāi)車去上班,但我的駕駛水平遠(yuǎn)遠(yuǎn)不如專業(yè)車手锰霜;類似的情況筹误,天天編程可能并不足以使你成為一名專業(yè)的程序員。那么癣缅,什么才能把一個(gè)普通人變成一名專業(yè)車手或者專業(yè)程序員呢厨剪?你需要鍛煉什么呢?
答案就在《科學(xué)美國(guó)人》的一篇名為“The Expert Mind”(專家思維)的文章里:
愛(ài)立信提出友存,重要的并不是經(jīng)驗(yàn)本身祷膳,而是“努力的學(xué)習(xí)”,也就是要不斷地挑戰(zhàn)自身能力之外的東西屡立。一些狂熱的愛(ài)好者花費(fèi)了大量的時(shí)間去下棋直晨、打高爾夫球或者玩樂(lè)器,但他們可能始終停留在業(yè)余水平上膨俐,而一個(gè)訓(xùn)練有素的學(xué)生卻可以在相對(duì)較短的時(shí)間里超越他們勇皇,原因就在這里。值得注意的是焚刺,在提高水平方面敛摘,花費(fèi)在下棋上的大量時(shí)間(即使參加各種比賽)似乎還是比不過(guò)專門的訓(xùn)練來(lái)得更為有效。訓(xùn)練的主要價(jià)值在于發(fā)現(xiàn)弱點(diǎn)檩坚,并有針對(duì)性地進(jìn)行提高着撩。
“努力的學(xué)習(xí)”意味著诅福,要常常去處理那些剛好在你能力極限上的問(wèn)題,也就是那些對(duì)你來(lái)說(shuō)有很大可能失敗的事情拖叙。如果不經(jīng)歷一些失敗的話氓润,你可能就不會(huì)成長(zhǎng)。你必須不斷地挑戰(zhàn)自我薯鳍,超越自己的極限咖气。
那樣的挑戰(zhàn)有時(shí)會(huì)在工作中碰到,但也未必挖滤。將鍛煉從職業(yè)工作中分離出來(lái)崩溪,這在編程領(lǐng)域常被人稱為“編碼套路”(Code Kata)。Code Kata的概念是由David Thomas提出的斩松,他是《程序員修煉之道:從小工到專家》的作者之一伶唯。這個(gè)概念主要指的是,針對(duì)某一種特定技術(shù)或技能進(jìn)行重復(fù)性的練習(xí)惧盹,從而將其熟練掌握乳幸。——譯者注
所謂套路钧椰,就是一系列的招式粹断。這個(gè)概念借鑒于武術(shù)。SteveYegge提出了一些不錯(cuò)的建議,“實(shí)踐演練”:
1. 寫一份自己的簡(jiǎn)歷嫡霞。把自己所有的相關(guān)技能都羅列出來(lái)瓶埋,然后把那些在100年后還用得到的標(biāo)出來(lái)。給每個(gè)技能打分诊沪,滿分為10分养筒。
2. 羅列出你所景仰的程序員。盡量包括那些與你一起工作的人娄徊,因?yàn)槟銜?huì)在工作中從他們身上獲取一些技能闽颇。記錄下他們身上的1 ~ 2個(gè)閃光點(diǎn),也就是你希望自己有所提高的方面寄锐。
4. 花20分鐘通讀別人的代碼兵多。讀出色的代碼和讀糟糕的代碼都是有益的,兩者都要讀橄仆,輪流切換剩膘。如果你無(wú)法感覺(jué)出它們之間的區(qū)別,可以求助于一位你尊敬的程序員盆顾,讓他給你展示一下什么是出色的代碼怠褐、什么是糟糕的代碼。把你讀過(guò)的代碼給別人也看看您宪,問(wèn)問(wèn)他們的看法奈懒。
5. 羅列出你最喜歡的10個(gè)編程工具——那些你覺(jué)得你用得最多奠涌、非有不行的工具。隨機(jī)挑選其中的一個(gè)工具磷杏,花一個(gè)小時(shí)去閱讀它的文檔溜畅。在這一個(gè)小時(shí)里,努力去學(xué)習(xí)這個(gè)工具的某個(gè)你不曾意識(shí)到的新功能极祸,或者發(fā)現(xiàn)某種新的使用方法慈格。
6. 想一想,除了編程之外你最擅長(zhǎng)什么事情遥金?再想一想浴捆,你是通過(guò)怎樣的鍛煉才變得如此熟練和專業(yè)的?這對(duì)于你的編程工作又有什么啟發(fā)呢稿械?(怎么把這些經(jīng)驗(yàn)應(yīng)用到編程方面选泻?)
9. 進(jìn)行一次技術(shù)面試,并且被面試的人應(yīng)該是某個(gè)你不太了解的領(lǐng)域里的專家美莫。讓他假定聽(tīng)眾在該領(lǐng)域里一無(wú)所知滔金,因此請(qǐng)他從最基礎(chǔ)的講起。努力去理解他所說(shuō)的茂嗓,必要時(shí)問(wèn)一些問(wèn)題。
10. 有機(jī)會(huì)參與別人的技術(shù)面試科阎。期間述吸,你只是認(rèn)真地聽(tīng)、認(rèn)真地學(xué)锣笨。在應(yīng)聘者努力解決技術(shù)問(wèn)題的同時(shí)蝌矛,你也要在自己腦子里嘗試解決這些問(wèn)題。
11. 找到一個(gè)能和你交換實(shí)際問(wèn)題的人错英,每隔一周入撒,相互交流編程問(wèn)題⊥盅遥花10 ~ 15分鐘來(lái)嘗試解決這些問(wèn)題茅逮,再用10 ~ 15分鐘進(jìn)行討論(無(wú)論能否解決)。
我之所以喜歡Steve開(kāi)出的這個(gè)清單判哥,是因?yàn)樗瓷先ズ苋嫦籽拧S行┏绦騿T一想到“鍛煉”,總認(rèn)為就是一些編碼上的難題塌计。但在我看來(lái)挺身,編程更在于人,而不是代碼锌仅。因此章钾,通過(guò)解決世上所有的墙贱、并且晦澀的編程面試題目,在提高你的個(gè)人能力方面贱傀,這種方法是有局限的惨撇。
實(shí)際上,在我看來(lái)窍箍,“編程套路”只需兩個(gè)招式:
1. 寫博客串纺。我在2004年初創(chuàng)辦了CodingHorror.com博客,作為我自己努力學(xué)習(xí)的一種形式椰棘。它在一開(kāi)始很不起眼纺棺,到后來(lái)成為我職業(yè)生涯中做過(guò)的最重要的一件事。所以邪狞,你也應(yīng)該寫博客祷蝌。最后“聞達(dá)于天下”的人,往往就是那些能夠有效書(shū)寫和溝通的人帆卓。他們的聲音最響亮巨朦,是他們?cè)谥贫ㄓ螒蛞?guī)則,并且引領(lǐng)世界的潮流剑令。
2. 積極參與著名的開(kāi)源項(xiàng)目糊啡。所有的高談闊論聽(tīng)起來(lái)都很好,但是吁津,你是一個(gè)大話王還是一名實(shí)干家呢棚蓄?別光說(shuō)不練,這個(gè)非常重要碍脏,因?yàn)槿藗儠?huì)用你的行動(dòng)來(lái)衡量你梭依,而不是你的言論。努力在公眾面前留下些實(shí)實(shí)在在有用的東西吧典尾,到時(shí)候你就可以說(shuō)役拴,“我在那個(gè)項(xiàng)目中出過(guò)力〖毓。”