一定要! !
TL;DR:名稱不明確的函數隱藏了意圖並使讀者感到困惑。使用描述性的、面向行動的名稱。
以通用術語命名的函數迫使讀者深入研究實作以理解其行為。
這會浪費時間並增加出錯的機會。
在使用獨立函數時,命名變得更加重要,因為類別名稱不提供額外的上下文。
這個問題直接關係到告訴,不要問的原則。
命令式名稱不會暴露迫使呼叫者推斷功能的模糊行為,而是傳達確切的操作,引導讀者無需檢查程式碼。
當您以描述性方式命名函數時,您可以消除不必要的猜測並符合此原則。
public String dateFormatting(Date date) { return new SimpleDateFormat("yyyy-MM-dd").format(date); } public void load() { System.out.println("Loading..."); }
public String formatDate(Date date) { return new SimpleDateFormat("yyyy-MM-dd").format(date); } public void loadUserPreferences() { System.out.println("Loading user preferences..."); }
[X] 手冊
您可以透過檢查使用模糊術語的函數名稱來檢測這種氣味,例如do、run、process、loadload
等自動 linter 可以標記這些模式或反白顯示具有過於通用名稱的函數。
[X] 初學者
函數名稱應該在其名稱和功能之間創建清晰的一一對應關係。
打破這種雙射會迫使開發人員檢查程式碼細節以了解上下文,從而減慢調試、審查和擴展速度。
人工智慧工具有時會在不了解您的領域的情況下產生通用函數名稱。
使用 AI 時,指定函數名稱必須具有描述性且面向操作。
人工智慧模型可以透過將函數簽名與預先定義的命名最佳實踐進行比較來幫助檢測不明確的名稱。
將人工智慧與手動程式碼審查結合會產生最佳結果。
記住:人工智慧助理會犯很多錯誤
Without Proper Instructions | With Specific Instructions |
---|---|
ChatGPT | ChatGPT |
Claude | Claude |
Perplexity | Perplexity |
Copilot | Copilot |
Gemini | Gemini |
函數名稱不僅僅是標籤;它們是與讀者的合約。
不明確的名稱會破壞此契約並導致混亂。
描述性的、以操作為導向的名稱簡化了溝通,並使您的程式碼更易於維護和擴展。
程式碼味道是我的觀點。
照片由 unsplash 上的 britishlibrary 拍攝
函數名稱應該是動詞或動詞片語,需要是
有意義
羅伯特·C·馬丁
本文是 CodeSmell 系列的一部分。
以上是程式碼異味 - 非命令式函數名稱的詳細內容。更多資訊請關注PHP中文網其他相關文章!