程序員如何做到『編程速度又快,Bug 數量又少』?

jopen 9年前發布 | 5K 次閱讀 程序員

有網友在 Quora 提問:如何把自己訓練得『編程速度又快,Bug 數量又少』?下面是 Glyn Williams 的回復很精彩,4.5 k 贊。

三個程序員被要求穿過一片田地,到達另一側的房子。

菜鳥程序員目測了一下之間很短的距離,說:“不遠!我只要十分鐘。”

資深程序員看了一眼田地,想了一會,說:“我應該能在一天內過去。”菜鳥程序員很驚訝。

大神程序員看了一眼田地,說:“看起來要十分鐘,但我覺得十五分鐘應該夠了。” 資深程序員冷笑了一聲。

菜鳥程序員出發了,但只過了一會,地雷爆炸了,炸出了巨大的洞。這下他必須偏移預定的路線,原路返回,反復嘗試穿過田地。最后他花了兩天到達目的地,到的時候顫顫發抖,還受了傷。

資深程序員一出發就匍匐前進,仔細地拍打地面,尋找地雷,只有在安全的時候才前進。他在一天的時間內小心謹慎地緩慢爬過了這片地,只觸發了幾個地雷。

大神程序員出發之后徑直穿過了田地,十分果斷。他只用了十分鐘就到了另一邊。

“你是怎么做到的?”另外兩個人問道,“那些地雷怎么沒有傷到你?”

“很簡單,”他回答道,“我最初就沒有地雷。”

當我們遇到我們(或其他人)給自己埋下的邏輯炸彈,編程會變得很困難。我們天天在編寫邏輯炸彈。它們就在地表下靜靜地待著,等著爆炸。一旦爆炸,通常就帶來不可預測的嚴重后果。

隨著新的代碼模塊被加入到項目中,項目的復雜度會上升。這種上升不是線性的,而是呈某種指數形式。

程序員的精力是一種有限的資源,所以這種爆炸式增長的復雜度最終會淹沒程序員。你的大腦最終會不堪重負,這是一個轉折點。

這就是炸彈開始爆炸的時刻。有各種各樣的炸彈:在遍歷時修改數組,數組下標偶爾變成負數,另一個線程在你的函數執行的起點和終點中間改變對象的狀態。轟,轟,轟……

我認為最快捷可靠的程序設計需要培養一種避免這些問題的風格。

編寫明確表達行為的代碼。選擇有意義、準確、無歧義的符號名字。嚴格執行命名方案,不要用不同的單詞描述同一個事物。

如果有,采用最簡單的解決方案。不要為速度優化,而是為可讀性和透明度優化。

如果你在最初編寫代碼時沒有注意可重用性,不要欺騙自己相信代碼可以很神奇地被重用。相反,應該從一種情形著手,保持代碼的具體性。如果值得修改代碼讓它一般化,那么應該做好徹底重寫的準備。

William Emmanuel Yu 的回復:(5.5k 贊)

for (;;) practice(); 
來自:http://www.techug.com/programming-fast-and-bug-less

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!