自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

如何防止程序代碼腐爛

開發(fā) 開發(fā)工具
代碼腐爛的意思,就是程序中的代碼本來運行良好,但過段時間后就變得臃腫,難以維護(hù)。我們該如何應(yīng)對這樣的問題?請看本文。

  很多團(tuán)隊都有這個問題,一個項目的代碼本來開始設(shè)計得好好的,一段時間以后,代碼就會變得難以理解,難以維護(hù),難以修改。為什么?我一直在思考這個問題。

  讓我們先看一個人的情況。

  1.程序員的成長

  新手的代碼

  新手的代碼沒有經(jīng)驗,基本不考慮代碼設(shè)計,代碼規(guī)模稍稍大一點則自己就亂了。

  進(jìn)階者的代碼

  小規(guī)模的時候

大規(guī)模的時候

  進(jìn)階者已經(jīng)知道如何設(shè)計代碼,懂得代碼規(guī)則,但一般局限于一個模塊。規(guī)模一大,模塊間的調(diào)用就會比較混亂,難以維護(hù)。

  有經(jīng)驗者的代碼


 

  有經(jīng)驗者的代碼,模塊內(nèi)部代碼整潔,模塊之間層次清晰,有設(shè)計模式,有成熟的體系??梢员3珠L期的代碼整潔。

  那么一個團(tuán)隊里面會出現(xiàn)什么情況呢?似乎,我們只要讓一堆有經(jīng)驗的人來開發(fā),那么代碼必然不會出什么問題。可惜,事實不是這樣。

  2.背景

  代碼風(fēng)格的多樣性

  有這樣的。

  也有這樣的

  放眼一看,會發(fā)現(xiàn)不同的代碼風(fēng)格,不同的設(shè)計思想,不同的設(shè)計理念。每個程序員都有自己的代碼個性。

團(tuán)隊層次的差異

一個團(tuán)隊內(nèi)部有新人,有熟手,有牛人。一個設(shè)計好的架構(gòu)可能會變壞。

  3.原因

  風(fēng)格的融合

  當(dāng)程序員A和程序員B在一起的時候,會有如下變化

原本整潔的代碼變得不整潔了。

  進(jìn)度的壓力

進(jìn)度導(dǎo)致了“飛線”的產(chǎn)生,未經(jīng)設(shè)計的代碼在時間的借口下產(chǎn)生了。


 

  多個人修改一個模塊


 


 

4.本質(zhì)

 

  所有代碼腐爛問題的本質(zhì)是溝通問題。其表現(xiàn)又都可以統(tǒng)一為修改別人的代碼。

  當(dāng)一個程序員在沒有溝通的情況下,修改另一個程序員的模塊的代碼的時候,他可能不理解此模塊的設(shè)計思路,代碼結(jié)構(gòu),邏輯結(jié)構(gòu),于是按自己的想法去修改,雖然看起來解決了眼前的問題。但是留下了一個不穩(wěn)定因素。此因素可以通過重構(gòu)來解決。但是,大家都非常的“忙”,誰也沒有空時間去Review代碼,去溝通我改了你的哪里的代碼。所以不穩(wěn)定的因素越來越多,導(dǎo)致了代碼的腐爛。

  最快腐爛的代碼,一定是很多人在修改的代碼,相反,長期由一個人來維護(hù)的代碼,就不會那么容易腐爛。因為一個人不存在溝通的問題,他修改代碼的時候,明確的知道自己應(yīng)該怎樣去修改,怎樣讓代碼更整潔。

  5.解決

  就一個辦法,多溝通。

  當(dāng)你工作的時候需要修改別人的代碼的時候,應(yīng)該先找這個人溝通。說清楚需要改動的邏輯,然后盡量讓他來修改。這樣可以保證一塊代碼是由一個人維護(hù),這樣成本最少。

  如果此人真的太忙,沒有時間,那么你必須說明你的計劃,讓他做一個建議,***能讓他給你講講此模塊的設(shè)計思路,代碼設(shè)計,邏輯設(shè)計,現(xiàn)在的問題,以后的計劃。保證你修改的代碼都是合理的。

  最理想的狀態(tài)就是整個團(tuán)隊的思想是高度統(tǒng)一的,N個人可以像一個人那樣去工作。這個需要團(tuán)隊長期的磨合。

  你可以會想到,我們制定一個規(guī)范不就可以了么?紙面上的規(guī)范通常是不起作用的,成功團(tuán)隊的規(guī)范是在整個團(tuán)隊達(dá)到一個很高的水平以后總結(jié)的經(jīng)驗。與其說執(zhí)行規(guī)范,不如說是學(xué)習(xí)經(jīng)驗。MFC的代碼像是由一個人寫出來的,Office所有產(chǎn)品都像是一個人做出來的。這就是高度的統(tǒng)一。我們把微軟的規(guī)范搬過來,不一定就有效果。

代碼的腐爛都是由于沒有深入理解的情況下修改別人的代碼導(dǎo)致的。

  總結(jié)一下:

解決的方法就是任何修改之前確保經(jīng)過深入的溝通。

簡單的規(guī)則是一個模塊僅允許一個人維護(hù)。

理想的狀態(tài)是整個團(tuán)隊思想高度統(tǒng)一。

【編輯推薦】

  1. 初學(xué)者必看:如何為代碼編寫基本的文檔
  2. 程序代碼里的幽默精神
  3. 讀書百遍其義自見 好代碼你需要寫兩遍
  4. Dart語言慣用語——Dart中特有的代碼味道
  5. 自己動手開發(fā)***的代碼編輯器

 

責(zé)任編輯:彭凡 來源: 騰訊大講堂
相關(guān)推薦

2010-07-17 00:55:48

PHP Telnet

2013-07-29 14:28:43

JQueryJQuery實現(xiàn)分頁分頁程序代碼

2010-01-15 18:46:08

C++程序代碼

2010-07-13 09:29:37

socketUDP協(xié)議

2011-11-03 15:44:10

程序員

2021-07-05 06:51:43

流程代碼結(jié)構(gòu)

2009-06-03 14:42:21

Eclipse調(diào)試調(diào)試Java程序

2010-01-22 15:09:11

VB.NET下載程序

2009-06-17 14:29:50

java程序代碼

2023-11-17 11:55:54

Pythonretrying庫

2009-08-24 18:06:36

源程序代碼C#讀取XML文件

2010-03-23 14:12:43

Python開發(fā)Win

2010-01-15 10:48:29

C++程序代碼

2009-09-02 18:28:00

C#鼠標(biāo)位置

2014-01-16 13:36:17

2013-04-22 11:34:30

BadNews惡意程序移動安全

2010-05-28 10:53:07

Linux串口測試工具

2011-09-02 15:10:52

2015-11-05 10:16:33

2009-10-27 10:14:54

VB.NET正則表達(dá)式
點贊
收藏

51CTO技術(shù)棧公眾號