拒絕重寫(xiě)

  • 圖片來(lái)源:XKCD

昨天欣鳖,前老板找我吃午飯。還在等菜的時(shí)候茴厉,我們又開(kāi)始回憶當(dāng)初的公司泽台。他突然想起的一段細(xì)節(jié),讓我自慚形穢矾缓。

對(duì)了……還記不記得那次檢查 Dan(公司首位程序員)的代碼怀酷,你怎么評(píng)價(jià)的來(lái)著?

你說(shuō):「這寫(xiě)的也太亂了嗜闻,全重寫(xiě)蜕依!」

很可惜,飯桌上我沒(méi)勇氣承認(rèn)那是個(gè)錯(cuò)誤判斷琉雳。雖然样眠,程序確實(shí)寫(xiě)的很亂。但長(zhǎng)久以來(lái)的經(jīng)驗(yàn)告訴我翠肘,大部分的程序員看到別人寫(xiě)的代碼時(shí)都感覺(jué)「太爛了」檐束。如果讓他們回看自己幾年前寫(xiě)的代碼,他們一樣會(huì)覺(jué)得「太爛了」束倍。確實(shí)被丧,他們沒(méi)說(shuō)錯(cuò)盟戏,兩邊都很爛。

但是甥桂,如果篤信這些代碼需要重寫(xiě)柿究,那將是個(gè)十足的低級(jí)錯(cuò)誤

出于工作的強(qiáng)大慣性黄选,你現(xiàn)在可能還無(wú)法體會(huì)個(gè)中原因笛求。成堆非正式的「工作慣例」似乎都在暗示這么做是對(duì)的,但你真的能解釋么糕簿?

我很喜歡 Joel Spolsky 在『記得永遠(yuǎn)別這么做』中發(fā)表的看法:

我們是程序員。這是一種在內(nèi)心深處狡孔,更愿意把自己當(dāng)作建筑師的職業(yè)懂诗。所以當(dāng)大家初入崗位,第一件心事就是把眼前這片地鏟平苗膝,蓋上點(diǎn)真正了不起的東西殃恒。但對(duì)于日常的修繕——修修補(bǔ)補(bǔ)、優(yōu)化改造辱揭、養(yǎng)護(hù)花草——他們提不起興趣离唐。

他們的內(nèi)心總在催促著自己,拋開(kāi)現(xiàn)在的代碼從頭來(lái)過(guò)问窃,因?yàn)榭傆X(jué)得之前的代碼混亂不堪亥鬓。

但這時(shí)候,有趣的事情發(fā)生了:通常他們都想錯(cuò)了域庇。之所以先前的代碼紛亂如麻嵌戈,是因?yàn)橐粭l重要且基礎(chǔ)的編程公理:

「讀代碼,比寫(xiě)代碼更難听皿∈烨海」

這解釋了為什么代碼復(fù)用是如此困難。同時(shí)也解釋了為什么團(tuán)隊(duì)中每個(gè)人都在用不同的函數(shù)來(lái)拆分字符串尉姨。比起搞懂老函數(shù)艱深的運(yùn)行原理庵朝,編寫(xiě)新的函數(shù)顯然更簡(jiǎn)單,還更有樂(lè)趣又厉。

這一公理帶來(lái)的效應(yīng)就是九府,當(dāng)你詢(xún)問(wèn)任何一個(gè)程序員他們手頭的代碼質(zhì)量如何,「一團(tuán)糟覆致,」他們準(zhǔn)會(huì)這么回答:「我寧可刪了再寫(xiě)一遍昔逗。」

當(dāng)新招聘的一名工程師表示要重寫(xiě)那些還在流暢工作的程序時(shí)篷朵,反對(duì)他準(zhǔn)沒(méi)錯(cuò)勾怒∑排牛或許他會(huì)說(shuō) Java 太老太慢, Ruby on Rails 多么多么酷笔链;或許他還會(huì)甩出一堆時(shí)髦的術(shù)語(yǔ)段只。但無(wú)論如何,保持冷靜的思考鉴扫。

你覺(jué)得呢赞枕?

版權(quán)聲明:
譯文版權(quán)屬于作者 @jprichardson ,并受法律保護(hù)坪创。除非評(píng)論正文中另有聲明炕婶,沒(méi)有作者本人的書(shū)面許可任何人不得轉(zhuǎn)載或使用整體或任何部分的內(nèi)容。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末莱预,一起剝皮案震驚了整個(gè)濱河市柠掂,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌依沮,老刑警劉巖涯贞,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異危喉,居然都是意外死亡宋渔,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)辜限,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)皇拣,“玉大人,你說(shuō)我怎么就攤上這事薄嫡∩蟠牛” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵岂座,是天一觀的道長(zhǎng)态蒂。 經(jīng)常有香客問(wèn)我,道長(zhǎng)费什,這世上最難降的妖魔是什么钾恢? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮鸳址,結(jié)果婚禮上瘩蚪,老公的妹妹穿的比我還像新娘。我一直安慰自己稿黍,他們只是感情好疹瘦,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著巡球,像睡著了一般言沐。 火紅的嫁衣襯著肌膚如雪邓嘹。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,031評(píng)論 1 285
  • 那天险胰,我揣著相機(jī)與錄音汹押,去河邊找鬼。 笑死起便,一個(gè)胖子當(dāng)著我的面吹牛棚贾,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播榆综,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼妙痹,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了鼻疮?” 一聲冷哼從身側(cè)響起怯伊,我...
    開(kāi)封第一講書(shū)人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎陋守,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體利赋,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡水评,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了媚送。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片中燥。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖塘偎,靈堂內(nèi)的尸體忽然破棺而出疗涉,到底是詐尸還是另有隱情,我是刑警寧澤吟秩,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布咱扣,位于F島的核電站,受9級(jí)特大地震影響涵防,放射性物質(zhì)發(fā)生泄漏闹伪。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一壮池、第九天 我趴在偏房一處隱蔽的房頂上張望偏瓤。 院中可真熱鬧,春花似錦椰憋、人聲如沸厅克。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)证舟。三九已至硕旗,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間褪储,已是汗流浹背卵渴。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留鲤竹,地道東北人浪读。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像辛藻,于是被迫代替她去往敵國(guó)和親碘橘。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容