【譯】重構(gòu)之前

每一個(gè)程序員有時(shí)候都需要重構(gòu)已有代碼。但在這么做之前卷哩,先思考一下下面這些事情,這可以節(jié)省你和其他人大量的時(shí)間(和苦惱):

  • 開始重構(gòu)的最佳方式是了解現(xiàn)有代碼庫并針對(duì)這些代碼編寫測試指黎。這有助于你了解這些代碼目前的優(yōu)點(diǎn)和弱點(diǎn)芯砸。這樣你就可以在避免錯(cuò)誤的同時(shí)保留寫得好的部分。我們都認(rèn)為我們能夠做的比現(xiàn)有系統(tǒng)好…直到最后并淋,由于我們沒有從現(xiàn)有系統(tǒng)的錯(cuò)誤中吸取教訓(xùn)寓搬,導(dǎo)致相比之前沒有什么提升,甚至更糟县耽。
  • 避免重寫的誘惑句喷。最好的方式是盡可能的重用,無論多么丑的代碼兔毙,至少它經(jīng)過了測試唾琼、審查等等。拋棄現(xiàn)有代碼澎剥,尤其是在現(xiàn)有產(chǎn)品中的代碼锡溯,意味著拋棄幾個(gè)月(可能是數(shù)年)的測試,久經(jīng)沙場的代碼可能包含一些你不知道的臨時(shí)方案和 bug 修復(fù)哑姚。如果你沒有考慮到這些祭饭,你新寫的代碼可能就會(huì)重現(xiàn)那些在舊代碼中已經(jīng)修復(fù)的離奇問題。這將浪費(fèi)多年來所花費(fèi)的大量時(shí)間叙量,精力和收獲的知識(shí)倡蝙。
  • 大量的迭代更新比一次巨大的改動(dòng)更好。增量更新可以通過反饋更輕松地衡量對(duì)系統(tǒng)的影響宛乃,比如通過測試悠咱。當(dāng)你修改了某處后,看見數(shù)百個(gè)測試失敗征炼,這一點(diǎn)也不好玩析既。可能讓你很有壓力并且感覺很糟糕谆奥,可能導(dǎo)致做出更糟糕的決策眼坏。少量的測試失敗比較容易處理,而且有很多處理的辦法。
  • 在每次迭代后宰译,確遍苎粒現(xiàn)有測試都通過很重要。如果現(xiàn)有測試不夠覆蓋你的改動(dòng)沿侈,就補(bǔ)充新的測試闯第。千萬不要輕易刪掉舊的測試代碼。表面上看這些測試似乎對(duì)你的新設(shè)計(jì)沒什么用缀拭,但是深入地挖掘?yàn)槭裁匆砑舆@些測試很有價(jià)值咳短。
  • 不應(yīng)該帶入個(gè)人偏好和一些主觀的內(nèi)容。如果這些代碼沒有問題蛛淋,干嘛要?jiǎng)铀茫看a風(fēng)格或結(jié)構(gòu)不符合你的偏好,這不是一個(gè)好的重構(gòu)理由褐荷。自認(rèn)為你可能比之前的人做的更好也不是一個(gè)正當(dāng)?shù)睦碛伞?/li>
  • 新技術(shù)不是一個(gè)充分的重構(gòu)理由勾效。一個(gè)糟糕的重構(gòu)理由是,因?yàn)楝F(xiàn)有代碼還沒有使用當(dāng)前最酷的技術(shù)叛甫,而且認(rèn)為新的語言或框架可以做的更優(yōu)雅层宫。除非有成本-效益分析顯示新語言或框架,在功能性合溺、可維護(hù)性和生產(chǎn)效率上有顯著提升卒密,否則最好保持原樣。
  • 切記棠赛,是人都會(huì)犯錯(cuò)誤哮奇。重構(gòu)不能保證新代碼總會(huì)更好,甚至不如以前睛约。我見過也親身經(jīng)歷過幾次失敗的重構(gòu)鼎俘。它不完美,但人力可為辩涝。

原文:Before You Refactor · 97 Things Every Programmer Should Know

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末贸伐,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子怔揩,更是在濱河造成了極大的恐慌捉邢,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件商膊,死亡現(xiàn)場離奇詭異伏伐,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)晕拆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門藐翎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事吝镣〉唐鳎” “怎么了?”我有些...
    開封第一講書人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵末贾,是天一觀的道長闸溃。 經(jīng)常有香客問我,道長未舟,這世上最難降的妖魔是什么圈暗? 我笑而不...
    開封第一講書人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮裕膀,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘勇哗。我一直安慰自己昼扛,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開白布欲诺。 她就那樣靜靜地躺著抄谐,像睡著了一般。 火紅的嫁衣襯著肌膚如雪扰法。 梳的紋絲不亂的頭發(fā)上蛹含,一...
    開封第一講書人閱讀 51,190評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音塞颁,去河邊找鬼浦箱。 笑死,一個(gè)胖子當(dāng)著我的面吹牛祠锣,可吹牛的內(nèi)容都是我干的酷窥。 我是一名探鬼主播,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼伴网,長吁一口氣:“原來是場噩夢啊……” “哼蓬推!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起澡腾,我...
    開封第一講書人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤沸伏,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后动分,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體毅糟,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年刺啦,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了留特。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖蜕青,靈堂內(nèi)的尸體忽然破棺而出苟蹈,到底是詐尸還是另有隱情,我是刑警寧澤右核,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布慧脱,位于F島的核電站,受9級(jí)特大地震影響贺喝,放射性物質(zhì)發(fā)生泄漏菱鸥。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一躏鱼、第九天 我趴在偏房一處隱蔽的房頂上張望氮采。 院中可真熱鬧,春花似錦染苛、人聲如沸鹊漠。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽躯概。三九已至,卻和暖如春畔师,著一層夾襖步出監(jiān)牢的瞬間娶靡,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來泰國打工看锉, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留姿锭,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓度陆,卻偏偏與公主長得像艾凯,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子懂傀,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354

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

  • 遺留代碼 其他人那兒得來的代碼趾诗; 錯(cuò)綜復(fù)雜,難以理清的結(jié)構(gòu)蹬蚁,需要改變?nèi)欢鴮?shí)際上又根本不能理解的代碼恃泪; 沒有編寫相應(yīng)...
    賈尼閱讀 3,341評(píng)論 1 6
  • 原文地址:The Mistakes I Made As a Beginner Programmer原文作者:Sam...
    柯振旭閱讀 543評(píng)論 1 1
  • chapter 1 重構(gòu),第一個(gè)案例 1.1 什么時(shí)候需要重構(gòu) 需要為程序添加一個(gè)特性犀斋,但代碼結(jié)構(gòu)無法使自己方便的...
    VictorBXv閱讀 2,033評(píng)論 0 1
  • 資料來源:重構(gòu)(Ruby版) 重構(gòu)的基本原理 重構(gòu)的起源 很難說清楚重構(gòu)這個(gè)詞究竟是什么時(shí)候誕生的贝乎。優(yōu)秀的程序員肯...
    好_好先生閱讀 724評(píng)論 0 1
  • 一、整潔代碼 A.混亂的代價(jià) 1.有些團(tuán)隊(duì)在項(xiàng)目初期進(jìn)展迅速叽粹,但有那么一兩年的時(shí)間卻慢去蝸行览效。對(duì)代碼的每次修改都影...
    ZyBlog閱讀 2,036評(píng)論 0 2