可持續(xù)開發(fā)不僅在于項目架構設計,還與代碼質量密切相關,代碼的整潔度和質量成正比?!?Robert C. Martin, “Clean Code”
如果你還沒有發(fā)現(xiàn)代碼質量的區(qū)別,如果你從未見過優(yōu)秀的代碼,或者從未見過糟糕的代碼,那么本文將以直觀地對比,告訴你代碼質量究竟會有多大的區(qū)別。
[ 代碼量 ]
我們知道代碼量顯示著功能的復雜程度,例如Windows XP的代碼量超過2000萬行,Linux內核有1500萬行(2012年)。然而代碼量和功能數(shù)量之間并非線性關系。
優(yōu)秀的設計中,代碼量和功能數(shù)的關系是這樣的:
糟糕的設計中,代碼量和功能數(shù)的關系是這樣的:
優(yōu)秀的系統(tǒng)往往會有優(yōu)秀的結構設計:層次清晰、職責單一、模塊化,方便擴展或者復用。功能的添加往往只是在現(xiàn)有框架中添加少量代碼。
然而糟糕的設計中,層次混亂、互相耦合、難以閱讀,既難以復用又不易擴展。每當被要求添加功能時,不得不幾乎完整地實現(xiàn)整個功能的流程,并修復與原系統(tǒng)的所有兼容問題。
[ 注釋]
優(yōu)秀的代碼中,注釋是這樣的:
糟糕的代碼中,注釋是這樣的:
最愚蠢的程序員都能寫出機器能讀懂的代碼,而優(yōu)秀的程序員能寫出人可以讀懂的代碼。
程序的注釋是為了讓人讀得懂。多數(shù)優(yōu)秀的代碼中,注釋幾乎接近代碼行數(shù)的一半,描述函數(shù)功能、解釋參數(shù)配置、指出陷阱所在。而糟糕的代碼中不僅不含這些注釋,甚至會保留大量殘余代碼,可讀性差又難以重構。
[ 命名]
優(yōu)秀的代碼中,命名是這樣的:
糟糕的代碼中,命名是這樣的:
命名是為了讓代碼更加容易閱讀,使用規(guī)范的術語不僅更加易懂,同時也是開發(fā)者知識水平和開發(fā)經驗的表現(xiàn)。如果說以中文拼音命名顯得奇怪,那么直接以a, b, c, d命名的便會顯得可恨,誰記得你的a是神馬東西!
看一個經典的例子,字符串替換:
稍微有點Javascript常識的便會想到正則表達式:
何必拷貝這一堆的代碼給老板看呢?開發(fā)中確實有很多時候,直接拷貝代碼既能立竿見影地完成功能,又不會影響原有功能。但這樣的代碼多起來之后,萬一功能調整你便需要重新debug所有的副本?;ㄒ恍r間學習更優(yōu)雅的用法是值得的。
[ 函數(shù) ]
保持函數(shù)的短小,使你的代碼更加易讀,例如:
將復雜的邏輯分步驟完成。如果寫在一起將會是這樣的:
相信我,一旦你寫了這樣的函數(shù),它會隨著時間的推移變得越來越長,直到有一天,你也忘了其中的一段代碼到底是做什么的。
事實上,復雜的函數(shù)不僅可以按照步驟劃分,更應按照層次來細化。不要在一個函數(shù)中進行不同層次的操作,否則它會變得非常難懂。
-
代碼
+關注
關注
30文章
4779瀏覽量
68521 -
程序員
+關注
關注
4文章
951瀏覽量
29798
原文標題:沒有對比就沒有傷害,優(yōu)秀的代碼VS糟糕的代碼
文章出處:【微信號:xx-cyy,微信公眾號:C語言編程基礎】歡迎添加關注!文章轉載請注明出處。
發(fā)布評論請先 登錄
相關推薦
評論