日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

阿里巴巴对Java编程【命名风格】的规约

發布時間:2023/12/3 java 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 阿里巴巴对Java编程【命名风格】的规约 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

轉載自?阿里巴巴對Java編程【命名風格】的規約

命名風格



1. 【強制】代碼中的命名均不能以下劃線或美元符號開始,也不能以下劃線或美元符號結束。

反例: _name / __name / $Object / name_ / name$ / Object$


2. 【強制】代碼中的命名嚴禁使用拼音與英文混合的方式,更不允許直接使用中文的方式。

說明:正確的英文拼寫和語法可以讓閱讀者易于理解,避免歧義。注意,即使純拼音命名方式

也要避免采用。

正例: alibaba / ?taobao / ?youku / ?hangzhou 等國際通用的名稱,可視同英文。

反例: DaZhePromotion [ 打折 ] / ?getPingfenByName() [ 評分 ] / ?int 某變量 = 3


3. 【強制】類名使用 UpperCamelCase 風格,必須遵從駝峰形式,但以下情形例外: DO / ?BO ?/DTO / ?VO / ?AO

正例: MarcoPolo / ?UserDO / ?XmlService / ?TcpUdpDeal / ?TaPromotion

反例: macroPolo / ?UserDo / ?XMLService / ?TCPUDPDeal / ?TAPromotion


4. 【強制】方法名、參數名、成員變量、局部變量都統一使用 lowerCamelCase 風格,必須遵從駝峰形式。

正例: ?localValue / ?getHttpMessage() / ?inputUserId


5. 【強制】常量命名全部大寫,單詞間用下劃線隔開,力求語義表達完整清楚,不要嫌名字長。

正例: MAX _ STOCK _ COUNT

反例: MAX _ COUNT


6. 【強制】抽象類命名使用 Abstract 或 Base 開頭 ; 異常類命名使用 Exception 結尾 ; 測試類命名以它要測試的類的名稱開始,以 Test 結尾。


7. 【強制】中括號是數組類型的一部分,數組定義如下: String[] args;

反例:使用 String args[] 的方式來定義。


8. 【強制】 POJO 類中布爾類型的變量,都不要加 is ,否則部分框架解析會引起序列化錯誤。

反例:定義為基本數據類型 Boolean isDeleted; 的屬性,它的方法也是isDeleted() , RPC框架在反向解析的時候,“以為”對應的屬性名稱是 deleted ,導致屬性獲取不到,進而拋出異常。


9. 【強制】包名統一使用小寫,點分隔符之間有且僅有一個自然語義的英語單詞。包名統一使用單數形式,但是類名如果有復數含義,類名可以使用復數形式。

正例: 應用工具類包名為 com . alibaba . open . util 、類名為 MessageUtils( 此規則參考spring 的框架結構 )


10. 【強制】杜絕完全不規范的縮寫,避免望文不知義。

反例: AbstractClass “縮寫”命名成 AbsClass;condition “縮寫”命名成 ?condi ,此類隨意縮寫嚴重降低了代碼的可閱讀性。


11. 【推薦】為了達到代碼自解釋的目標,任何自定義編程元素在命名時,使用盡量完整的單詞組合來表達其意。

正例:從遠程倉庫拉取代碼的類命名為 PullCodeFromRemoteRepository。

反例:變量 int a; 的隨意命名方式。


12. 【推薦】如果模塊、接口、類、方法使用了設計模式,在命名時體現出具體模式。

說明:將設計模式體現在名字中,有利于閱讀者快速理解架構設計理念。

正例: public class OrderFactory;

public class LoginProxy;

public class ResourceObserver;


13. 【推薦】接口類中的方法和屬性不要加任何修飾符號 (public 也不要加 ) ,保持代碼的簡潔性,并加上有效的 Javadoc 注釋。盡量不要在接口里定義變量,如果一定要定義變量,肯定是與接口方法相關,并且是整個應用的基礎常量。

正例:接口方法簽名: void f();

接口基礎常量表示: String COMPANY = " alibaba " ;

反例:接口方法定義: public abstract void f();

說明: JDK 8 中接口允許有默認實現,那么這個 default 方法,是對所有實現類都有價值的默認實現。


14. 接口和實現類的命名有兩套規則:

1 ) 【強制】對于 Service 和 DAO 類,基于 SOA 的理念,暴露出來的服務一定是接口,內部的實現類用 Impl 的后綴與接口區別。

正例: CacheServiceImpl 實現 CacheService 接口。

2 ) ?【推薦】 如果是形容能力的接口名稱,取對應的形容詞做接口名 ( 通常是– able 的形式 ) 。

正例: AbstractTranslator 實現 ?Translatable 。


15. 【參考】枚舉類名建議帶上 Enum 后綴,枚舉成員名稱需要全大寫,單詞間用下劃線隔開。

說明:枚舉其實就是特殊的常量類,且構造方法被默認強制是私有。

正例:枚舉名字為 ProcessStatusEnum 的 成員名稱: SUCCESS / ?UNKOWN _ REASON 。


16. 【參考】各層命名規約:

A) Service / DAO 層方法命名規約

1 ) 獲取單個對象的方法用 get 做前綴。

2 ) 獲取多個對象的方法用 list 做前綴。

3 ) 獲取統計值的方法用 count 做前綴。

4 ) 插入的方法用 save/insert 做前綴。

5 ) 刪除的方法用 remove/delete 做前綴。

6 ) 修改的方法用 update 做前綴。

B) 領域模型命名規約

1 ) 數據對象: xxxDO , xxx 即為數據表名。

2 ) 數據傳輸對象: xxxDTO , xxx 為業務領域相關的名稱。

3 ) 展示對象: xxxVO , xxx 一般為網頁名稱。

4 ) POJO 是 DO / DTO / BO / VO 的統稱,禁止命名成 xxxPOJO 。


總結

以上是生活随笔為你收集整理的阿里巴巴对Java编程【命名风格】的规约的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。