首頁 >後端開發 >php教程 >你必須了解的10個程式設計的技巧

你必須了解的10個程式設計的技巧

ringa_lee
ringa_lee原創
2017-09-17 10:25:461587瀏覽

摘要:何以敲出一手好程式碼?好程式碼可以定義為易讀、易懂、易調試、易改,最重要的還要少缺陷。顯然,要想敲出一手好程式碼,是要花不少時間,但這在長久來看是有意義的,因為你可以花更少時間及精力去維護和復用你的程式碼。這是來自一位30位軟體經驗的老程式設計師的總結。

                                            

好程式碼可以定義為易讀、易懂、易調試、易改,最重要的還要少缺陷。顯然,要想敲出一手好程式碼,是要花不少時間,但這在長久來看是有意義的,因為你可以花更少時間及精力去維護和復用你的程式碼。

事實上,我們可以將好程式碼等同於可重複使用的程式碼,這也是下面提到的重要原則之一。程式碼可能只是完成了程式設計工作中短期目標的特定功能,但如果沒人(包括你自己)願意重複使用你的程式碼,這程式碼在某種程度上可以說是不足且有缺陷的。要嘛太複雜、要嘛太具體、要嘛在不同情況下極有可能崩掉,或者其他程式設計師可能不相信你的程式碼。

下面無論你的經驗程度如何,如果你始終如一地將下面的妙招應用到你的程式碼中(包括你的實驗或原型),那麼一手好程式碼隨手可得。

1、 遵循單一責任原則

函數在程式設計師的函式庫中是單一最重要的抽象形式。可以重複使用的機會越多,你要寫的程式碼就越少,這些程式碼就越可靠。遵循單一責任原則的小小函數更有可能被重新使用。

2、最小化共享狀態

應該將函數之間的隱式共享狀態最小化,無論它是文件作用域變數還是物件的成員字段,這有利於顯式地將所需的值作為參數。當明確函數實現所需結果時,程式碼變得容易理解和重複使用。

對此可以得出一個結論,你應該優先選擇靜態無狀態變數而不是物件的成員變數。

3、在地化副作用

理想的副作用(例如列印到控制台、記錄、改變全域狀態、檔案系統操作等)應該放置在單獨的模組中,而不是分散在整個程式碼中。功能上的副作用往往違反了單一的責任原則。

4、優先選擇不可變的物件

如果一個物件的狀態在其建構函式中設定一次,並且不再次更改,則除錯變得容易得多,因為一旦建構正確就保持有效。這是降低軟體專案複雜性最簡單的方法之一。

5、多用介面少用類別

接受介面的函式(或C++中的範本參數或概念)比在類別上操作的函式可重用性更強。

6、對模組應用良好的原則

將軟體專案分解成更小的模組(例如程式庫和應用程式),以實現模組化重用。模組的一些關鍵原則是:

  1. 最小化依賴關係

  2. 每個專案都應該有單一明確的功能

  3. 不要重複

你應該努力讓你的專案保持小巧和明確。

7.避免繼承

在物件導向程式設計中,繼承,特別是虛擬函數在可重用性方面往往是一個死穴。我很少能成功地使用能覆蓋類別的函式庫。

8.同設計和開發一樣進行測試

我並不是測試驅動開發的鐵桿擁護者,但在你開始編寫測試程式碼時,編寫測試自然遵循了許多指導方針。它也有助於提早將錯誤暴露出來。避免編寫無用的測試,良好的編碼意味著更高級的測試(例如,單元測試中的整合測試或功能測試)在顯示缺陷方面更有效。

9.優先選擇而不是手寫標準庫

我無法告訴你需要多久才能看到一個std :: vector 或std :: string 更好的版本,但它幾乎總是浪費時間和精力。除了一個顯而易見的事實,那就是你正在把 bug 引入一個新的地方。 (請參閱技巧10)其他程式設計師不太可能重複使用您的程式碼,而不是那些被廣泛理解、支援和測試的程式碼。

10.避免寫新代碼

最重要的一點是,每位程式設計師應遵循:“The best code is the code that isn't written” (最好的程式碼是不用被複寫的程式碼)。你的程式碼越多,缺陷就越多,找到並修復 bug 就越困難。

在寫一行程式碼之前先問問自己,有沒有一個工具,函數或函式庫已經做了你所需要的功能?你真的需要自己去實作這個功能,而不是呼叫另一個已經存在的功能嗎?
總結
程式設計就好比是一種藝術形式或一項運動,你只有透過不斷地練習,不斷地向他人學習,才能不斷地提高程式碼的質量,這些都將有利於你成為更有效率的程式設計師。

以上是你必須了解的10個程式設計的技巧的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn