Soft_Job 板


LINE

專案要不要重構,因專案規模、時機、文化而異。 以下是根據我個人開發經驗的觀點: 我認為重構需要考量三個要點:動機、時機、理由。 1. 動機:為什麼需要重構 代碼畢竟是工具,不是文學,能帶來效益最重要。 要構成需求的強力條件是,安全性和耦合性。 當有具體新增功能需求的時候,修改原代碼容易導致錯誤風險提高。 當功能需要刪減的時候,原代碼無法快速拆分,且預期有多處時。 需要多方協作,而原代碼無法有效拆解,嚴重影響協同開放時。 代碼過於複雜導致難以維護。 代碼規模已經導致效能低落。 這些原因都是直接導致產品需求無法實現。 2. 時機:什麼時候該做 不為太遠的未來,而為不久的將來。 重構是為了可預見的功能拓展而做,不是為了不存在的以後而做。 當有功能拓展的可能性的時候,要規劃重構,避免技術債累積。 當產品需求和定位還不確定的時候,以最有效率開發的方式做。 舉例來說,開放解一元二次方程式的功能好了, 如果只是算法的一個步驟,直接一個函式搞定。 如果專案是要製作一個數學工具,那可重構可解N次的工具。 但如果動機是前者,卻去重構成後者,就不是對的時機。 3. 理由:巧立名目 重構的特點是不改變原本功能,所以通常不具功勞。 所以要配合具體產品需求再做。例如: 需要增刪改功能,需要重構不然做不到。 產品要做效能提升,需要重構不然會卡死。 專案需要開啟合作,需要重構不然無法協作。 專案需要交接給營運,需要重構不然難以維護。 不過通常交接了誰跟你重構,吃力不討好。 說白了,重構本質上是利他行為,願意做的都是好人。 好處不在增加功勞,而是提升管理效率這種隱藏成本, 也沒有一定要重構,而是取決於動機和時機, 取得一個有用和好維護的平衡。 至於要不要因為好讀或好看而重構,我覺得不值得。 代碼的原則歸原則、模式歸模式,滿足很好,只要不影響開發效率。 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 118.232.100.61 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Soft_Job/M.1743362099.A.DDF.html
1F:→ marra: 不改沒事,一改出事,才是真的麻煩! 03/31 03:21
2F:推 zyxx: 推 講得清楚 03/31 09:13
3F:→ fatb: 有經驗的都知道改了超容易出事 一般底層別亂搞這種事情 03/31 11:09
4F:→ fatb: 高層改出錯可以主導整個重構事件找出問題 低層改出錯高層只 03/31 11:11
5F:→ fatb: 會覺得案子這麼趕了你還在給我找麻煩 03/31 11:11
6F:推 philip80220: 推 03/31 12:40
7F:推 PeanutZombie: 推 03/31 16:22
8F:推 viper9709: 覺得解N次方程式的例子不錯 04/01 00:26
9F:→ michellehot: 確實 不論是改上層還是底層 只要不是同一個人寫的 04/01 00:42
10F:→ michellehot: 就很容易出錯 不過我想這可以是另一個主題了XD 04/01 00:42
11F:推 aspirev3: 先把舊code增加測試如何 04/01 13:19
12F:→ labbat: 樓上說得好,那麼誰來提供測資例子 04/01 20:56
13F:推 v86861062: 推推 04/01 23:19
14F:推 Aidan79225: 測資當然是想重構的人想辦法 04/02 08:32
15F:推 ricky60324: 重構成一坨 也可以再重構一次 工作永動機 04/02 09:15
16F:推 internetms52: 呃...要改的東西太多了,那就改天吧 04/02 13:53
17F:→ labbat: 不是所有人都精通的,有重構專業的不一定有測資專業呀 04/02 15:41
18F:推 NDark: 真的要做好重構很精實 但是事倍功半 只是自己的修行 04/02 17:13







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:WOW站內搜尋

TOP