心目中的程式設計高手zz, The best coder

執筆記憶的空白發表於2014-07-20

MIT BBS 上說微軟電話面試的一道題就是“Who do you think is the best coder,and why? ”。我覺得挺有意思的,也來湊個熱鬧。排名不分先後。

Bill Joy, 前任Sun 的首席科學家,當年在Berkeley 時主持開發了最早版本的BSD 。他還是vi 和csh 的作者。當然,Csh Programming Considered Harmful 是另一個話題樂。據說他想看看自己能不能寫個作業系統,就在三天裡寫了個自己的Unix, 也就是BSD 的前身。當然是傳說了,但足見他的功力。另一個傳說是,1980 年初的時候,DARPA 讓BBN 在Berkley Unix 里加上BBN 開發的TCP/IP 程式碼。但當時還是研究生的B 伯伯怒了,拒絕把BBNTCP/IP 加入BSD ,因為他覺得BBN 的TCP/IP 寫得不好。於是B 伯伯出手了,端的是一箭封喉,很快就寫出了高效能的伯克利版TCP/IP 。當時 BBN 和DARPA 簽了鉅額合同開發TCP/IP Stack ,誰知他們的程式碼還不如一個研究生的好。於是他們開會。只見當時B 伯伯穿個T-shirt 出現在會議室( 當時穿T-shirt 不象現在,還是相當散漫的哈) 。只見BBN 問:你怎麼寫出來的?而B 伯伯答:簡單,你讀協議,然後程式設計就行了。最令偶暈倒的是,B 伯伯碩士畢業後決定到工業界發展,於是就到了當時只有一間辦公室的Sun, 然後他就把Sparc 設計出來樂。。。象這種軟硬通吃的牛人,想不佩服都不行的說。據Bill Joy 的同事說,一般開會的時候B 伯伯總是拿一堆雜誌漫不經心地讀。但往往在關鍵之處,B伯伯發言,直切要害,提出漂亮的構想,讓同事們徹底崩潰。對了,他還是Java Spec 和JINI 的主要作者之一。


John Carmack ,ID Software 的founder 和Lead Programmer 。上個月和一個搞圖形的師兄聊天,他竟然不知道John Carmack, 也讓偶大大地暈了一把。不過也許搞研究的和搞實戰的多少有些隔吧。想必喜歡第一人稱射擊遊戲的都知道J 哥哥。90 年代初只要能在PC 上搞個小動畫都能讓人驚歎一番的時候,J 哥哥就推出了石破天驚的Castle Wolfstein, 然後再接再勵,doom, doomII, Quake... 每次都把3-D 技術推到極限。J 哥哥的簡歷上說自己的專長是"Exhaust 3-D technology" ,真是牛人之言不我欺的說。做J 哥哥這樣的人是很幸福的,因為各大圖形卡廠家一有了新產品就要向他“ 進貢" ,不然如果他的遊戲不支援哪種卡,哪種卡基本就會夭折樂。當初MS的Direct3D 也得聽取他的意見,修改了不少API 。當然,J 哥哥在結婚前十數年如一日地每天程式設計14 小時以上,也是偶們凡人望塵莫及的。對了,J 哥哥高中肆業( ?) ,可以說是自學成才。不過呢,誰要用這個例子來為自己學習不好辯護,就大錯特錯了。那 Leonardo Da Vinci 還是自學成才呢( 人是私生子,不能上學) 。普通人和天才還是有區別的。對了,其實偶們叫“ 達分奇” 是相當不對的,因為Vinci 是地名,而Da Vinci 就是從Vinci 來的人的意思。換句話說,Leonardo Da Vinci 就是“ 從Vinci 來的Leonardo” 的意思。叫別人“Da Vinci” 就不知所謂樂。嗯,扯遠了,打住。


David Cutler ,VMS 和Windows NT 的首席設計師,去微軟前號稱矽谷最牛的kernel 開發員。當初他和他的手下在微軟一週內把一個具備基本功能的bootable kernel 寫出來,然後說:“who can't write an OS in a week?" ,也是牛氣沖天的說。順便說一句,D 爺爺到NT3.5 時,管理1500 名開發員,自己還兼做設計和程式設計,不改coder 本色啊。

D 爺爺天生脾氣火爆,和人爭論時喜歡雙手猛擊桌子以壯聲勢。日常交談fuck 不離口。他面試祕書時必問:"what do you think of the word 'fuck'?" ,讓無數美女剎羽而歸。終於有一天,一個同樣火爆的女面對這個問題脫口而出:"That's my favoriteword" 。於是她被錄取樂,為D 爺爺工作到NT3.5 釋出。

Don Knuth 。高爺爺其實用不著偶多說。學程式設計的不知道他就好像學物理的不知道牛頓,學數學的不知道尤拉,學音樂的不知道莫扎特,學Delphi 的不知到 Anders Hejlsberg ,或者學Linux 不知道Linus Torvalds 一樣,不可原諒啊。為了讓文章完整,就再羅唆幾句吧。高爺爺本科時就開始給行行色色的公司寫各種稀奇古怪的編譯器掙外快了。他賣給別人時收一兩千美元,那些公司拿了code ,加工一下賣出去就是上萬上十萬。不過也沒見高爺爺不爽過,學者本色的說。想想那可是60 年代初啊,高爺爺寫編譯器寫多了,順帶就搞出了個 Attribute Grammar和LR(k) ,大大地造福後人啊。至於高爺爺在CalTech 的程式設計比賽( 有Alan Kay 得眾多高高手參加) 總是第一,寫的Tex 到86 年就code freeze ,還附帶2^n 美分獎勵等等都是耳熟能詳的,偶就不饒舌樂。

順便說一下,高老大爺是無可爭議的寫作高手。他給Concrete Mathematics 寫的前言可謂字字鏗鏘,堪為前言的典範。他的技術文章也是一絕,文風細緻,解釋精當,而且沒有學究氣,不失輕快跳脫。記得幾年前讀Concrete Mathemathics ,時不時開懷大笑,讓老媽極其鬱悶,覺得我nerdy 到家,不可救藥。其實呢,子非魚,安知魚之樂,更不知那完全是高爺爺的功勞。說到寫作高手,不能不提Stephen A. Cook 。他的文章當年就被我們的寫作老師極力推薦,號稱典雅文風的樣本。庫爺爺一頭銀髮,身材頎長,總是面帶謙和的微笑,頗有仙風道骨,正好和他的仙文相配的說。

高爺爺其實還是開源運動的先驅。雖然他沒有象Richard Stallman 那樣八方奔走,但他捐獻了好多作品,都可以在網上看到,比如著名的Mathematical Writing ,MMIXWare ,The Tex Book 等,更不用說足以讓他流芳百世的Tex樂。

Ken Thompson ,C 語言前身B 語言的作者,Unix 的發明人之一( 另一個是Dennis M. Riche 老大,被尊為DMR),Belle( 一個厲害的國際象棋程式) 的作者之一, 作業系統Plan 9 的主要作者( 另一個是大牛人Rob Pike, 前不久被google 挖走了) 。Ken 爺爺也算是計算機歷史上開天闢地的人物了。1969 年還是
計算機史前時代,普通人都認為只有大型機才能執行通用的作業系統,小型機只有高山仰止的份兒。至於用高階語言來寫作業系統,更是笑談。Ken 爺爺自然不是池中物,於是他和DMR 怒了,在 1969 年到1970 間用匯編在PDP-7 上寫出了UNIX 的第一個版本。他們並不知道,一場轟轟烈烈的UNIX 傳奇由此拉開了序幕。Ken 爺爺在1971 年又把Unix 用C 重寫,於是C 在隨後20 年成就了不知多少豪傑的夢想和光榮。

Ken 爺爺還有段佳話: 裝了UNIX 的PDP-11 最早被安裝在Bell Lab 裡供大家日常使用。很快大家就發現Ken 爺爺總能進入他們的帳戶,獲得最高許可權。Bell Lab 裡的科學家都心比天高,當然被搞得鬱悶無比。於是有高手怒了,跳出來分析了UNIX 程式碼,找到後門,修改程式碼,然後重新編譯了整個UNIX 。就在大 家都以為“ 這個世界清淨了”的時候,他們發現Ken 爺爺還是輕而易舉地拿到他們的帳戶許可權,百思不解後,只好繼續鬱悶。誰知道這一鬱悶,就鬱悶了14 年, 直到Ken 爺爺道出箇中緣由。原來,程式碼
裡的確有後門,但後門不在Unix 程式碼裡,而在編譯Unix 程式碼的C 編譯器裡。每次C 編譯器編譯UNIX 的程式碼,就自動生成後門程式碼。而整個Bell Lab 的人,都是用Ken 爺爺的C 編譯器。

Rob Pike, AT&T Bell Lab 前Member of Technical Staff ,現在google 研究作業系統 。羅伯伯是Unix 的先驅,是貝爾實驗室最早和Ken Thompson 以及Dennis M. Ritche 開發 Unix 的猛人,UTF-8 的設計人。他還在美國名嘴DavidLetterman 的晚間節目上露了一小臉,一臉憨厚地幫一胖子吹牛搞怪。讓偶佩服不已的是,羅伯伯還是1980 年奧運會射箭的銀牌得主。他還是個頗為厲害的業餘天文學家,設計的珈瑪射線望遠鏡差點被NASA 用在太空梭上。他還是兩本經典, The Unix Programming Environment 和 The Practice of Programming 的作者之一。如果初學者想在程式設計方面精益求精,實在該好好讀讀這兩本書。它們都有中文版的說。羅伯伯還寫出了Unix下第一個基於點陣圖的視窗系統,並且是著名的blit 終端的作者。當然了,羅伯伯還是號稱銳意革新的作業系統,Plan9 ,的主要作者。可惜的是,Plan9 並沒有引起多少人的注意。羅伯伯一怒之下,寫出了振聾發聵的雄文Systems Software Research is Irrelevant ,痛斥當下系統開發的不思進取,固步自封的弊病。雖然這篇文章是羅伯伯含忿出手,頗有偏激之詞,但確實道出了系統開發的無奈:開發週期越來越長,代價越來越大,使用者被統一到少數幾個系統上,結果越來越多的活動是測量和修補,而真正的革新越來越少。

就在羅伯伯鬱悶之極的 時候,google 登門求賢來樂。如果說現在還有一家大眾公司在不遺餘力地把系統開發推向極致的話,也就是google 樂。隨便看看google 的成果就知道了。具有超強容錯和負載平衡能力的分散式檔案系統GFS( 現在能夠用100,000 臺廉價PC 搭起一個巨型分佈系統,並且高效便宜地進行管理的系統也不多哈) ,大規模機器學習系統( 拼寫檢查,廣告匹配,拼音搜尋。。。哪個都很牛的說) ,更不用說處理海量平行計算的各式google 服務了。Rob 在 System Software Research is Irrelevant 裡蕭瑟地說現在沒有人再關心繫統研究的前沿成果了。想不到他錯了,應為google 關心。google 網路了大批功成總是試圖吸取系統研究的最新成果。想必Rob Pike 在google 很幸福。願他做出更棒的系統。

Dennis M. Ritchie, 既然Ken Thompson 是我的偶像,新聞組上人稱DMR 的Dennis M.Ritchie 自然也是,畢竟兩人共同締造了UNIX ,而Dennis 幾乎獨力把C 搞大( 當然,C 的前身是B ,而B 是Ken Thompson 一手做出來的)。兩人1983 年分享圖靈獎,是有史以來少數幾個因工程專案得獎的工程師( 本來是唯一的一對兒,但Alan Kay 才因為SmallTalk 得獎,所以就成了唯二的樂) 一個人一生能做出一個卓越的系統已經不易,DMR 的C 和UNIX 長盛不衰近30 年,至今生機勃勃,DMR 此生可以無憾的說。

D 爺爺也算有 家學淵源:他老爸在AT&T 貝爾實驗室工作了一輩子,並在電路設計方面卓有成就,還出了本頗有影響的書The Design of Switching Circuits ,據說在交換理論和邏輯設計方面有獨到的論述。當然,D 爺爺和他老爸是不同時代的人:他老爸的研究成形於電晶體發明之前,而D 爺爺的工作離了電晶體就玩兒不轉樂。:-D

不要看D 爺爺搞出了C ,其實他最愛的程式語言是Alef ,在Plan9 上執行,支援並行程式設計。Alef 的 語法和C 相似,但資料型別和執行方式都和C 大大不同。說到語言,D 爺爺對後來人有非常中肯的建議:抱著學習的目的來開發你自己的語言,不要冀望於它被眾人接受。這個建議不光對語言開發有用,也適用於其它大型系統的開發。別的不說,DMR 後來領導自己的團隊在1995 年和1996 分別推出了Plan9 和 Inferno 作業系統,又用多少人知道呢?其實,D 爺爺當初也沒想過C 會風行世界。他開發C 的初衷和Eric S. Raymond 在Cathedral and Bazaar 裡闡述的一樣,就是要消除自己對現有工具的不爽之處。誰知D 爺爺無心插柳,C 竟然受到眾多程式設計師的狂熱擁戴,連D 爺爺自己都大惑不解。在一次
採訪中D 爺爺說大概那是因為C 的抽象程度碰巧既滿足了程式設計師的要求, 又容易實現。當然C 一度是Unix 上的通用語言也是原因。但不管怎麼說,D 爺爺對程式語言出色的審美意識奠定了C 廣為流傳的基礎。

最 後八卦一下。D 爺爺的業餘愛好和NBA 大牛Karl Malone 一樣:開卡車。不過D 爺爺更喜歡開NASCAR ,而KM獨愛巨無霸。J D 爺爺自稱心中不供偶像,如果一定要說一個,那就是Ken Thompson 了。現在Ken 爺爺退休當飛機教練去了,而D 爺爺當了貝爾實驗室系統開發部的頭,整日忙於開支票。他倆合作20 年,屢屢創造歷史。這段令人神往的佳話,也就長留你我心中樂。

P.S., 很多人都以為Brian W. Kernighan 是C 的作者。其實BWK 只是寫了那本經典K&R C 。據D 爺爺說,他,Ken, 和Kernighan 三人中,Kernighan 最能寫文章,他次之,而Ken 寫得最少;但說到程式設計,Ken 爺爺才是當之無愧的老大。


Edsger Wybe Dijkstra, 對,就是E.W. Dijkstra. 一提到EWD ,很多人就會想起找最短路徑的Dijkstra Algorithm,就好像一提到Sir. Tony Hoare ,就想起Quick Sort 一樣。其實這些個演算法不過是兩個牛人在他們職業生涯中最瑣碎的貢獻。比如Dijkstra 演算法,無非是戴爺爺在1956 年為了展示新計算機 ARMAC 的計算能力,初試身手的成果,屬於他的演算法處女作。據戴爺爺自述,他搞出最短路徑演算法的時候連紙筆都沒用。當時他和他老婆在阿姆斯特丹一家咖啡廳的陽臺上曬太陽喝咖啡,突然就把這個演算法想出來樂。而且當時的演算法研究還比較原始,牛人們忙著用計算機搞數值計算,對離散演算法不屑一顧。那時連一個象樣的專注於離散演算法的專業期刊都沒有。戴爺爺於是推遲發表這個演算法。直到1959 年,他才把這個演算法發表在Numerische Mathematik 的創刊號上,權為捧場。:-)
EWD 在多個領域牛氣沖天,端的是理論和程式設計兩手硬 的高手 。只不過他的很多工作比較深刻,學校的老先生們覺得本科生接受不了,不給本科生講而已。

戴爺爺大概因為最短路徑演算法一戰成名,於是有人請他參加另一臺計算機X1 的設計工作,並且把設計實時中斷系統的任務派給了他。現在看來實時中斷也許不算什麼,但要知到,X1 前根本就沒有實時中斷的概念。實現它簡直就是一場豪賭。戴爺爺起初還不情願,但經不住專案負責人Bram 和Carel 的輪番 “ 吹捧” :我們知道實時中斷讓您工作變得非常困難,但象您這樣的牛人肯定能做出來的說。結果戴爺爺被糖衣炮彈徹底擊穿,接下了這個燙手山芋。兩三年後,他不僅搞出了實時中斷,還圍繞這個寫出了自己的博士論文,順利戴上博士帽。

讓戴爺爺真正成名立萬的還是在X1 上開發的Algo60 ,最早的高階語言之一。戴爺爺沒日沒夜地工作了8 個月,就搞出了Algo60 ,也因此獲得了 1972 年的圖靈獎。因為Algo60 ,戴爺爺發表了一篇石破天驚的文章:Recursive Programming ,於是人們才知道,原來高階語言也可以高效地實現遞迴,原來從此以後,所有程式設計師都不可避免地和戴爺爺發明的一個詞( 應該說是概 念) 打交道:堆疊。而且Algo60 還讓戴爺爺深入地思考多道程式設計的問題,最終發明了每個系統程式設計師都繞不開的概念:semaphore 。當然,戴爺爺總是把他發明的概念嚴格形式化,極具科學家本色的說。和這些成就想比,他提出的吃飯的哲學家問題,也就沒什麼好說的了。

說來好笑,當時 的大學( 忘了哪所了) 還是覺得戴爺爺沒有受過正統的數學訓練,也不是專門搞數值分析的,所以最後不太情願地給了他一個教職。這種小挫折並不能妨礙象戴爺爺這樣的牛人創造歷史。他一邊教數值分析(:-D),一邊開始開發一個新的作業系統,並培養電腦科學家。幾年後,THE Multiprogramming System 橫空出世。THE 是第一個支援鬆散耦合,顯式同步的程式並由此使得嚴格證明系統沒有死鎖變得容易的作業系統。可惜戴爺爺任職的系不識貨,還強行解散了他的研究小組(1972 年戴爺爺給他的系主任說他得了圖靈獎,系主任的第一反應是你們搞計算機就喜歡亂髮獎) 。這讓戴爺爺相當鬱悶,得了抑鬱症。在極度鬱悶之中,戴爺爺決定用寫作來治療自己的抑鬱症。於是經典就誕生樂:Notes on Structured Programming 。戴爺爺從此被尊為結構化程式設計的奠基人,而且他的抑鬱症也被治好樂。


Anders Hejlsberg ,微軟.NET 的首席架構師,程式語言設計和實現的頂尖高手。他一手做出了Turbo Pascal,也是Delphi, J++( 尤其是WFC) ,C#, 和.NET 的主要作者。這些作品的名字足以為他立傳。作為一個程式設計師,我在這樣的大師面前實在無語。生子當如Anders 的說。李維的<> 裡 已詳細講述了Anders 的傳奇故事,我就不用費舌了:http: //java.mblogger.cn/iexploiter/posts/1505.aspx

Artima 上有Anders 談C# 的系列訪談。MSDN 上有一段Anders 導遊的錄影。有興趣可以去看看牛人的丰采。


原文出自:http://blog.csdn.net/q969403688/article/details/7884891

相關文章