天才程序員不為人知的秘密
最近在YouTube里看了一條谷歌大佬的公開演講,題目叫做The Myth of the Genius Programmer,翻譯過來就是天才程序員的秘密。這篇演講是兩位在谷歌subversion team工作的技術大佬Fitz和Ben在2009年Google IO上進行的,他們兩人在谷歌內部被公認為頂級的天才級程序員。于是他們基于此做出了分享,這篇視頻給了我很多啟發。
我后來在B站里找到了克隆版本,但是很遺憾的是,這個視頻由于知名度比較低,所以現在只有生肉。對于英語不好的同學來說可能看起來會比較吃力,所以我開辟了這個專題,希望能夠結合這篇視頻,把所有驚艷到我的觀點分享出來,希望也能給大家一些啟發。
靈魂拷問
演講的一開始,兩位大佬先拋出了一系列靈魂拷問。
有多少人是完全獨立編程,從來不與任何人合作?有多少人希望自己完全獨立編程?
有多少人會把code review當做是開發的必須流程之一?
有多少人不希望在別人面前犯二?
如果你已經是一個程序員的話,我想你的回答應該和大多數人是一致的。我們希望我們能更多地獨立完成一些事情,也不喜歡像是code review這樣繁文縟節的環節,我們自己保證代碼的質量就可以了嘛,為什么非常接受別人的審判呢?有的時候一些低級錯誤會讓我們顯得很傻,但錯誤在所難免不是嗎?
大佬們沒有直接給出觀點,但他們給出了一個事實,就是在Google,所有的代碼都必須經過code review才允許合并。其實這些問題與其說是強調code review的重要性,不如是拷問一下我們的心態,我們對于與人合作這件事情究竟有多么的包容。
走出洞穴
在一些美劇或者是一些電影當中,往往會被程序員描繪成躲在洞穴里的原始人。他們搗鼓著只有他們自己懂的東西,卻突然有一天拿出一款驚艷的產品來改變世界。
比如營銷號經常提到的寫出Linux系統內核的Linus,還有寫出Windows系統的比爾蓋茨等等。很多不明就里的程序員也是這么自居的,他們的內心也渴望著能夠成為一個這樣的原始人。但實際上事實是,世界上幾乎沒有任何一款被大眾所熟知或者是廣泛使用的軟件或者程序是由一個人寫出來的,Linus沒有寫出Linux系統,他完成的只是系統內核,Guido也沒有寫出完整的Python。這些營銷號傳頌的故事都是錯的。
渴望獨居,希望孤軍奮戰也許是眾多程序員們內心的渴望,但這樣其實是不對的,我們不能真住在洞穴里。Ben說由于他們負責的是subversion的開發,subversion就是一款類似于Git的產品,用來做代碼版本控制的。他說每年他們接收到最多的反饋就是,你們能不能做一個功能可以把我的一些提交隱藏起來?你們能不能把我的整個repo藏起來,直到我覺得代碼已經OK了才顯示?你們能不能提供把repo里代碼全部清除的功能?因為我覺得之前的代碼太蠢了?
要知道寫這些反饋的人都是Google的工程師,號稱是容納了全世界最多天才的地方。就這樣頂級公司的頂級工程師,居然會覺得自己的代碼蠢,也會想要隱藏起來不被他人看見。這其實某種程度上說明了,心態和實力也許并沒有什么關系。所謂的強者也可能有弱弱的心態。
bus factor
大佬們沒有生硬地告訴我們,不能當原始人,需要走出洞穴與其他人交流,再給一些雞湯什么的。他們提出了一個非常非常有意思的理論,叫做bus factor,即巴士因子。
這個理論是什么意思呢?想象你在一個開發小組當中,這個小組有一個大牛級的工程師,所有的方案設計以及技術細節他都了如指掌。有一天他上班的時候突然被巴士撞了,再也不能來上班了。請問這個小組會發生什么?也許不會一夜崩塌,但肯定會遭遇巨大的困難。對你而言一定非常痛苦,無數的問題得不到解決。
能夠讓一個核心程序員離職或者是離開的并不一定是車禍,還有許許多多其他的原因。比如他準備結婚了,生孩子了,中彩票了等等等等。一旦某一個核心程序員因為一些私人的原因離職,團隊就陷入混亂,那么說明這個團隊的巴士因子很高。即大量的技術依賴都在同一個人身上,相反如果核心的人員離職并不會引起震動和海嘯,那么這樣的團隊的巴士因子就很低,也就是說抗風險能力很強。
那怎么樣才能降低團隊內部的巴士因子呢?大佬們沒有明說,但答案已經就在眼前了,就是要走出洞穴,多多和其他同事交流,彼此做code review,知道對方都在做一些什么。
放下自我
單槍匹馬是做不出優秀的產品的,同樣單打獨斗也不可能成為行業中的大佬。我們向上攀登和成長的過程必然伴隨著與他人的交流和互相學習,我們不要懼怕這一點。
Fitz舉了Apache開源社區的例子,一群互不相識的工程師聚集在一起,完成了一款偉大的產品。但是在這個過程當中,人是比代碼更重要的東西。這些代碼不是憑空產生的,突然憑空得來一堆代碼并沒有任何意義。有意義的是一群工程師的靈感互相碰撞,互相啟發,彼此都覺得自己在做一件偉大的事情,彼此都為自己所做的事情為傲,在這個過程當中,大家都放下了自我。
放下自我的英文他用的是drop the ego,ego有自我和自尊的意思。我們放下自我,才可以接納別人的想法,才可以融入一個集體或者是社區當中,才能為了當下所做的事情驕傲。
尾聲這一篇作為開篇,主要講了這么幾點。人們想象中單打獨斗完成偉大作品的情況幾乎不不存在。偉大的產品往往都是一個團隊或者是一群人共同完成的。天才級別的程序員往往也不是一個人閉門造成就能成長成的,在這過程當中也少不了和團隊以及其他人的交流和學習。當我們置身在一個項目或者是團隊中的時候,要注意團隊里的巴士因子,也要放下自我,為了當下做的事情自豪,enjoy這個過程。
深刻的道理往往是樸實無華的,如果大家待過職場就會知道,如今的職場現狀主旋律就是浮躁。人人都在想著更好的機會,更好的發展,能夠專注眼前,專注團隊成長學習,專注手中事情的人少之又少。但我相信,只有這樣樸素追求的人才能把這條路長久地走下去,才能成為別人眼中的天才程序員。
最后,我把B站的鏈接放在原文當中,大家可以點擊閱讀原文跳轉。
本文轉載自微信公眾號「TechFlow」,可以通過以下二維碼關注。轉載本文請聯系TechFlow公眾號。