最牛B的編碼套路

最近,我大量閱讀了Steve Yegge的文章。其中有一篇叫“Practicing Programming”(練習編程),寫成於2005年,讀後令我驚訝不已:

與你所相信的恰恰相反,單純地每天埋頭於工作並不能算是真正意義上的鍛鍊——參加會議並不能鍛鍊你的人際交往能力;回覆郵件並不能提高你的打字水平。你必須定期留出時間,集中鍛鍊,這樣才能把事情做得更好。

我認識很多傑出的程序員——這是在亞馬遜工作最好的額外“福利”之一。如果仔細觀察他們,你會發現他們時時都在鍛鍊。他們已經很優秀了,但他們仍然不忘鍛鍊。他們鍛鍊的方法林林總總,而我在這篇文章中只會介紹其中的幾種。

據我瞭解,這些傑出程序員之所以如此成功,就是因爲他們一直在鍛鍊。完美的身材要靠定期的鍛鍊才能獲得,而且必須堅持鍛鍊才能保持,否則身材就會走形。對於編程和軟件工程來說,道理是一樣的。

這是一個重要的區別——我每天都開車去上班,但我的駕駛水平遠遠不如專業車手;類似的情況,天天編程可能並不足以使你成爲一名專業的程序員。那麼,什麼才能把一個普通人變成一名專業車手或者專業程序員呢?你需要鍛鍊什麼呢?

答案就在《科學美國人》的一篇名爲“The Expert Mind”(專家思維)的文章裏:

愛立信提出,重要的並不是經驗本身,而是“努力的學習”,也就是要不斷地挑戰自身能力之外的東西。一些狂熱的愛好者花費了大量的時間去下棋、打高爾夫球或者玩樂器,但他們可能始終停留在業餘水平上,而一個訓練有素的學生卻可以在相對較短的時間裏超越他們,原因就在這裏。值得注意的是,在提高水平方面,花費在下棋上的大量時間(即使參加各種比賽)似乎還是比不過專門的訓練來得更爲有效。訓練的主要價值在於發現弱點,並有針對性地進行提高。

“努力的學習”意味着,要常常去處理那些剛好在你能力極限上的問題,也就是那些對你來說有很大可能失敗的事情。如果不經歷一些失敗的話,你可能就不會成長。你必須不斷地挑戰自我,超越自己的極限。

那樣的挑戰有時會在工作中碰到,但也未必。將鍛鍊從職業工作中分離出來,這在編程領域常被人稱爲“編碼套路”(Code Kata)。

Code Kata的概念是由David Thomas提出的,他是《程序員修煉之道:從小工到專家》的作者之一。這個概念主要指的是,針對某一種特定技術或技能進行重複性的練習,從而將其熟練掌握。——譯者注

SouthEast


所謂套路,就是一系列的招式。這個概念借鑑於武術。

如果你想要看一些編碼套路的例子(也就是努力學習和磨練編程技能的方法),SteveYegge的文章裏倒是提出了一些不錯的建議。他把它們稱作爲“實踐演練”:

1.     寫一份自己的簡歷。把自己所有的相關技能都羅列出來,然後把那些在100年後還用得到的標出來。給每個技能打分,滿分爲10分。

2.     羅列出你所景仰的程序員。儘量包括那些與你一起工作的人,因爲你會在工作中從他們身上獲取一些技能。記錄下他們身上的1 ~ 2個閃光點,也就是你希望自己有所提高的方面。

3.     去查看維基百科(Wikipedia.Org)上“計算機科學”欄目,找到“計算機科學的卓越先驅”這部分,從這個列表中挑選一個人,閱讀他的事蹟,並且在閱讀時打開任何你感興趣的鏈接。

4.     20分鐘通讀別人的代碼。讀出色的代碼和讀糟糕的代碼都是有益的,兩者都要讀,輪流切換。如果你無法感覺出它們之間的區別,可以求助於一位你尊敬的程序員,讓他給你展示一下什麼是出色的代碼、什麼是糟糕的代碼。把你讀過的代碼給別人也看看,問問他們的看法。

5.     羅列出你最喜歡的10個編程工具——那些你覺得你用得最多、非有不行的工具。隨機挑選其中的一個工具,花一個小時去閱讀它的文檔。在這一個小時裏,努力去學習這個工具的某個你不曾意識到的新功能,或者發現某種新的使用方法。

6.     想一想,除了編程之外你最擅長什麼事情?再想一想,你是通過怎樣的鍛鍊才變得如此熟練和專業的?這對於你的編程工作又有什麼啓發呢?(怎麼把這些經驗應用到編程方面?)

7.     拿出一疊簡歷,並和一組面試官在同一個房間裏待上一個小時。確保每份簡歷都至少被3個面試官看過,並且要給出1 ~ 3分的評分。針對那些不同面試官評判大相徑庭的簡歷展開討論。

8.     參與一個電話面試。事後寫下你的反饋,拋出你的觀點,然後與主持電話面試的人聊一聊,看看你們是否達成了一致的結論。

9.     進行一次技術面試,並且被面試的人應該是某個你不太瞭解的領域裏的專家。讓他假定聽衆在該領域裏一無所知,因此請他從最基礎的講起。努力去理解他所說的,必要時問一些問題。

10.   有機會參與別人的技術面試。期間,你只是認真地聽、認真地學。在應聘者努力解決技術問題的同時,你也要在自己腦子裏嘗試解決這些問題。

11.   找到一個能和你交換實際問題的人,每隔一週,相互交流編程問題。花10 ~ 15分鐘來嘗試解決這些問題,再用10 ~ 15分鐘進行討論(無論能否解決)。

12.   當你聽到任何你一時之間也無法解決的面試問題時,趕緊回到你的座位上,把這個問題用電子郵件發給自己,以留作日後的提醒。在那一週裏找出點時間,用自己最喜歡的編程語言來解決它。

我之所以喜歡Steve開出的這個清單,是因爲它看上去很全面。有些程序員一想到“鍛鍊”,總認爲就是一些編碼上的難題。但在我看來,編程更在於人,而不是代碼。因此,通過解決世上所有的、並且晦澀的編程面試題目,在提高你的個人能力方面,這種方法是有侷限的。

關於“努力的學習”,我也很喜歡Peter Norvig在“Teach Yourself Programming in TenYears”(花10年時間自學編程)一文中提出的諸多建議:

1. 與別的程序員交流。讀別人的代碼。這比任何書籍或培訓課程都更重要。

2. 動手寫程序!最好的學習方法就是邊做邊學。

3. 在本科或研究生的課程中學習編程課程。

4. 找一些項目來做,並且需要與其他程序員形成團隊來合作。在項目的進行過程中,學會辨別最出色的程序員以及最糟糕的程序員。

5. 在項目中跟隨別的程序員一起工作,瞭解如何維護那些不是你寫的代碼,並且學習如何寫出利於他人維護的代碼。

6. 學習多種不同的編程語言,特別是那些與你現在所熟悉的語言有着不同的世界觀和編程模型的。

7. 瞭解硬件對軟件的影響。知道你的電腦執行一條指令需要多少時間,從內存中取出一個字(在有緩存或沒緩存的情況下)需要多少時間,在以太網(或者因特網)上傳輸數據需要多少時間,從磁盤中讀取連續的數據或者在磁盤上跳轉到另一個位置需要多少時間,等等。

你還可以從Dave Thomas的21種實用的編碼套路中獲取靈感(CodeKata.com),或者你更願意加入一個你家當地的“編程武館”(CodingDojo.org)。

對於“努力的學習”,我無法像Steve,Peter或者Dave那樣提供一個長長的建議列表。我遠不如他們有耐心。實際上,在我看來,“編程套路”只需兩個招式:

1.      寫博客。我在2004年初創辦了CodingHorror.com博客,作爲我自己努力學習的一種形式。它在一開始很不起眼,到後來成爲我職業生涯中做過的最重要的一件事。所以,你也應該寫博客。最後“聞達於天下”的人,往往就是那些能夠有效書寫和溝通的人。他們的聲音最響亮,是他們在制定遊戲規則,並且引領世界的潮流。

2.      積極參與著名的開源項目。所有的高談闊論聽起來都很好,但是,你是一個大話王還是一名實幹家呢?別光說不練,這個非常重要,因爲人們會用你的行動來衡量你,而不是你的言論。努力在公衆面前留下些實實在在有用的東西吧,到時候你就可以說,“我在那個項目中出過力。”

當你能編寫精彩的代碼、並且能用精彩的言辭向世人解釋那些代碼時,到那時候,我會覺得你已經掌握了最牛的編碼套路!


譯者:happydeer          來源:@豆巴陸其明

原文:https://sites.google.com/site/steveyegge2/practicing-programming


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章