當前位置:
首頁 > 科技 > 優秀程序員寫代碼一定會用的 11 條經驗!

優秀程序員寫代碼一定會用的 11 條經驗!

這是一篇值得收藏起來,隔三差五就拿來重讀的文章!因為作者向你保證,他「遇到的所有糟糕的代碼,都是因為沒採納這些實踐經驗。而任何一段優秀的代碼,都採納了至少部分實踐經驗。」

還等什麼?趕快看看這些經驗就是什麼吧?

我已經寫了20年代碼了,在此期間曾與17個團隊共事過,使用不同的語言做過數百個項目。

這些項目從最簡單的博客網站,到支持每秒3000多次請求的API,還有曾經熱賣過的應用。

根據這些經驗,再結合我讀過的書,我認為編程中最重要的是:可讀性。

可讀性

表面上看來,可讀性似乎很主觀。不同語言、代碼、和團隊對於可讀性的定義不盡相同。但如果深入本質的話,就會發現代碼可讀性有一些非常關鍵的因素。

許多程序員太傾向於計算機了,只要程序能運行就一了百了。儘管是老生常談,但這種方式完全斷絕了人參與的可能性。

最近幾個月, 我在努力將這些人為因素提煉成11條寫程序的實踐經驗,專門討論如何增強可讀性並降低複雜度。

我在BaseCode中寫過這些詳細內容,並將其應用到真實世界的代碼片段中。

許多人會認為這些太基礎、無關緊要,可以忽視。但我可以向你保證,我遇到的所有糟糕的代碼都是因為沒採納這些實踐經驗。而任何一段優秀的代碼都採納了至少部分實踐經驗。

格式

我們在格式上消耗了太多精力。製表符還是空格,Allman還是K&R。總會有一天,你會意識到格式在編程中並不是最重要的。

選擇一種格式,應用到代碼中,然後將這個過程自動化。然後就可以重新專註於寫代碼本身了。

死代碼

所有注釋掉的代碼塊、未使用的變數和無法到達的的代碼都是垃圾。他們就像在對讀者說,「我不關心這段代碼」。

於是惡性循環開始了。日復一日,死代碼最終會埋葬你的代碼。這正是經典的破窗效應。

必須要找出並幹掉死代碼。雖然不需要把精力主要放在這裡,但一定要時時留意。

嵌套代碼

邏輯幾乎是一切代碼的基礎。我們寫代碼是為了做決策、迭代和計算。一般情況下都會導致分支或嵌套,從而造成嵌套得很深的代碼塊。

雖然計算機很容易閱讀這種代碼,但對於人類則是非常大的精神負擔。因此,代碼會變得複雜、難以閱讀。應該通過防禦語句、提前返回或使用函數式編程等方式消滅嵌套代碼。

使用對象

儘管現在是面向對象編程的時代,我們依然使用了過多的原始指令。

長長的參數列表,雜亂的數據,自定義的數組或字典結構等。這些都可以重構成對象。

這樣不僅能讓數據結構變得正規,還能容納所有重複的、使用原始數據的重複的邏輯。

大型代碼塊

雖然沒有具體的數字,但代碼塊的長度應該是有限制的。如果你認為你的代碼塊過大,就應該對其進行識別、重組並重構。

這個簡單的過程可以讓你確定代碼塊的上下文和抽象級別,以便正確地找出代碼的任務,並將代碼重構到更加易於閱讀、更簡單的代碼塊中。

命名規則

當然,好的命名很困難,但只是因為我們人為增加了難度。有個小技巧在編程的許多方面都能用得上,包括命名,那就是——延後。不要糾結某個東西的命名,繼續寫代碼就好。

就算是用一整句話命名一個變數都沒問題,繼續寫代碼就好。我可以保證,當你完成整個功能之後,更好的名字就會浮出水面。

刪除注釋

在我看來這一條至關重要,刪了注釋我才能把精力放到可讀性上。不管我如何解釋刪除注釋的必要性,總會有人跟我抬杠,然後舉出一個絕對需要注釋的例子。

當然,如果哈勃望遠鏡要和古老的適配器連接,而後者返回一個意思不明的687,這種情況肯定需要注釋來說明。但大多數其他情況下,你應該盡量重寫代碼使得它不需要注釋也能看懂。

合理的返回

我們總是選擇返回最奇怪的值,特別是對於邊界條件的情況。像-1、687或null。然後就得寫很多代碼來處理這些值。實際上,null的創造者稱它為「10億美元的錯誤」。

應該努力返回更有意義的值。理想情況下,最好是即使在反面情況下也能讓調用者繼續執行的值。如果真的是異常情況,那麼最好用其他方式來通信,而不是使用null。

三的原則

考慮一下數學上的序列。給出數字2並問你,「下一個數字是什麼?」可能是3可能是4,但也可能是1或2.1。實際上你沒辦法知道。然後我提供了序列中的下一個數字2, 4然後問,「下一個是什麼?」可能是6,8,也可能是16。

同樣,儘管猜對的可能性增加了,但還是不能確定。然後我提供了數列中的第三個數字,2, 4, 16,然後問「下一個是什麼?」有了三個數字之後,程序員的大腦很容易看出這是個平方序列,於是確定下一個數字是256。這就是三的原則。

這個例子雖然跟編程沒關係,但它告訴我們,我們不應該太早做抽象。三的原則能阻止我們過早消除重複的努力,直到有了足夠多的信息後再做出決定。用Sandi Mets的話說,「重複的代價遠遠低於錯誤的抽象。」

對稱性

最後一條實踐經驗能給所有代碼的可讀性帶來詩一般的潤色,那就是對稱性。這條來自Kent Beck的《實現模式》一書,書中說到:

代碼中的對稱性是說,同樣的思想在任何地方都使用同樣的實現。

不過說起來容易做起來難。對稱性體現了編程的創造性。它是許多其他實踐的基礎:命名、結構、對象、模式等。不同語言之間、不同代碼之間和不同團隊之間對於對稱性的定義都可能不一樣。

因此,你需要花上許多年去追求對稱性。但是,一旦開始在代碼中使用對稱性,就會迅速呈現純粹的形式,代碼的形狀也會迅速變好。

原文:https://jason.pureconcepts.net/2018/09/practices-write-readable-code-less-complex/

作者:Jason McCreary,軟體工程師,專註於PHP和iOS應用。

譯者:彎月,責編:胡巍巍


喜歡這篇文章嗎?立刻分享出去讓更多人知道吧!

本站內容充實豐富,博大精深,小編精選每日熱門資訊,隨時更新,點擊「搶先收到最新資訊」瀏覽吧!


請您繼續閱讀更多來自 CSDN 的精彩文章:

竊取蘋果 1TB 敏感數據,這個少年憑什麼「全身而退」?
人工智慧時代,得開發者得天下!

TAG:CSDN |