Java命名規範參考!

目錄

Java中的命名規範

包命名

類命名

方法

返回真僞值的方法

用來檢查的方法

按需求才執行的方法

異步相關方法

回調方法

操作對象生命週期的方法

與集合操作相關的方法

與數據相關的方法

成對出現的動詞

變量&常量命名

變量命名

常量命名

通用命名規則

代碼註解

註解的原則

註解格式

包註解

類注接

屬性註解

方法註釋

構造方法註釋

注意點

總結


       簡潔清爽的代碼風格應該是大多數工程師所期待的。在工作中筆者常常因爲起名字而糾結,命名已經成爲我工作中的攔路虎,誇張點可以說是編程5分鐘,命名兩小時!

       每個公司都有不同的標準,目的是爲了保持統一,減少溝通成本,提升團隊研發效能。所以本文中是筆者結合阿里巴巴開發規範,以及工作中的見聞針對Java領域相關命名進行整理和總結,僅供參考。

Java中的命名規範

       好的命名能體現出代碼的特徵,含義或者是用途,讓閱讀者可以根據名稱的含義快速釐清程序的脈絡。不同語言中採用的命名形式大相徑庭,Java中常用到的命名形式共有三種,既首字母大寫的UpperCamelCase,首字母小寫的lowerCamelCase以及全部大寫的並用下劃線分割單詞的UPPERCAMELUNSER_SCORE。通常約定,類一般採用大駝峯命名,方法和局部變量使用小駝峯命名,而大寫下劃線命名通常是常量和枚舉中使用

包命名

       包名統一使用小寫“.”點分隔符之間有且僅有一個自然語義的英文單詞或者多個單詞自然連接到一塊(如 springframework,deepspace不需要使用任何分割)。包名統一使用單數形式,如果類命有複數含義,則可以使用複數形式。

       包名的構成可以分爲以下幾四部分【前綴】 【發起者名】【項目名】【模塊名】。常見的前綴可以分爲以下幾種:

類命名

       類名使用大駝峯命名形式,類命通常是名詞或名詞短語,接口名除了用名詞和名詞短語以外,還可以使用形容詞或形容詞短語,如Cloneable,Callable等,表示實現該接口的類有某種功能或能力。對於測試類則以它要測試的類開頭,以Test結尾,如HashMapTest。

       對於一些特殊特有名詞縮寫也可以使用全大寫命名,比如XMLHttpRequest,不過筆者認爲縮寫三個字母以內都大寫,超過三個字母則按照要給單詞算。這個沒有標準如阿里巴巴中fastjson用JSONObject作爲類命,而google則使用JsonObjectRequest命名,對於這種特殊的縮寫,原則是統一就好。

方法

       方法命名採用小駝峯的形式,首字小寫,往後的每個單詞首字母都要大寫。和類名不同的是,方法命名一般爲動詞或動詞短語,與參數或參數名共同組成動賓短語,即動詞 + 名詞。一個好的函數名一般能通過名字直接獲知該函數實現什麼樣的功能。

返回真僞值的方法

注:pre- prefix前綴,suf- suffix後綴,alo-alone 單獨使用

用來檢查的方法

按需求才執行的方法

異步相關方法

回調方法

操作對象生命週期的方法

與集合操作相關的方法

與數據相關的方法

成對出現的動詞

變量&常量命名

變量命名

       變量是指在程序運行中可以改變其值的量,包括成員變量和局部變量。變量名由多單詞組成時,第一個單詞的首字母小寫,其後單詞的首字母大寫,俗稱駱駝式命名法(也稱駝峯命名法),如 computedValues,index、變量命名時,儘量簡短且能清楚的表達變量的作用,命名體現具體的業務含義即可

       變量名不應以下劃線或美元符號開頭,儘管這在語法上是允許的。變量名應簡短且富於描述。變量名的選用應該易於記憶,即,能夠指出其用途。儘量避免單個字符的變量名,除非是一次性的臨時變量pojo中的布爾變量,都不要加is(數據庫中的布爾字段全都要加 is_ 前綴)

常量命名

       常量命名CONSTANT_CASE,一般採用全部大寫(作爲方法參數時除外),單詞間用下劃線分割。那麼什麼是常量呢?

       常量是在作用域內保持不變的值,一般使用final進行修飾。一般分爲三種,全局常量(public static final修飾),類內常量(private static final 修飾)以及局部常量(方法內,或者參數中的常量),局部常量比較特殊,通常採用小駝峯命名即可。

       常量一般都有自己的業務含義,不要害怕長度過長而進行省略或者縮寫。如,用戶消息緩存過期時間的表示,那種方式更佳清晰,交給你來評判。

通用命名規則

  1. 儘量不要使用拼音;杜絕拼音和英文混用。對於一些通用的表示或者難以用英文描述的可以採用拼音,一旦採用拼音就堅決不能和英文混用。正例:BeiJing, HangZhou 反例:validateCanShu
  2. 命名過程中儘量不要出現特殊的字符,常量除外。
  3. 儘量不要和jdk或者框架中已存在的類重名,也不能使用java中的關鍵字命名。
  4. 妙用介詞,for(可以用同音的4代替), to(可用同音的2代替), from, with,of等。如類名採用User4RedisDO,方法名getUserInfoFromRedis,convertJson2Map等。

代碼註解

註解的原則

       好的命名增加代碼閱讀性,代碼的命名往往有嚴格的限制。而註解不同,程序員往往可以自由發揮,單並不意味着可以爲所欲爲之胡作非爲。優雅的註解通常要滿足三要素

  1. Nothing is strange 沒有註解的代碼對於閱讀者非常不友好,哪怕代碼寫的在清除,閱讀者至少從心理上會有抵觸,更何況代碼中往往有許多複雜的邏輯,所以一定要寫註解,不僅要記錄代碼的邏輯,還有說清楚修改的邏輯。
  2. Less is more 從代碼維護角度來講,代碼中的註解一定是精華中的精華。合理清晰的命名能讓代碼易於理解,對於邏輯簡單且命名規範,能夠清楚表達代碼功能的代碼不需要註解。濫用註解會增加額外的負擔,更何況大部分都是廢話。
  3. Advance with the time 註解應該隨着代碼的變動而改變,註解表達的信息要與代碼中完全一致。通常情況下修改代碼後一定要修改註解

註解格式

       註解大體上可以分爲兩種,一種是javadoc註解,另一種是簡單註解。javadoc註解可以生成JavaAPI爲外部用戶提供有效的支持,javadoc註解通常在使用IDEA或者Eclipse等開發工具時都可以自動生成,也支持自定義的註解模板,僅需要對對應的字段進行解釋。參與同一項目開發的同學,儘量設置成相同的註解模板。

包註解

       包註解在工作中往往比較特殊,通過包註解可以快速知悉當前包下代碼是用來實現哪些功能,強烈建議工作中加上,尤其是對於一些比較複雜的包,包註解一般在包的根目錄下,名稱統一爲package-info.java

類注接

javadoc註解中,每個類都必須有註解。

屬性註解

       在每個屬性前面必須加上屬性註釋,通常有一下兩種形式,至於怎麼選擇,你高興就好,不過一個項目中要保持統一。

方法註釋

       在每個方法前面必須加上方法註釋,對於方法中的每個參數,以及返回值都要有說明。

構造方法註釋

       在每個構造方法前面必須加上註釋,註釋模板如下:

注意點

       而簡單註解往往是需要工程師自己定義,在使用註解時應該注意一下幾點:

  1. 枚舉類的各個屬性值都要使用註解,枚舉可以理解爲是常量,通常不會發生改變,通常會被在多個地方引用,對枚舉的修改和添加屬性通常會帶來很大的影響。
  2. 保持排版整潔,不要使用行尾註釋;雙斜槓和星號之後要用1個空格分隔。

總結

       無論是命名和註解,他們的目的都是爲了讓代碼和工程師進行對話,增強代碼的可讀性,可維護性。優秀的代碼往往能夠見名知意,註解往往是對命名的補充和完善。

發佈了75 篇原創文章 · 獲贊 79 · 訪問量 14萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章