Java良好的編碼風(fēng)格(一)

編程規(guī)約:

(一)命名規(guī)約

  1. 【強(qiáng)制】 代碼中的命名均不能以下劃線或美元符號開始贞岭,也不能以下劃線或美元符號結(jié)束。
    反例:_name / _name / $Object / name / name$ / Object$

  2. 【強(qiáng)制】類名使用 UpperCamelCase 風(fēng)格饱狂,必須遵從駝峰形式曹步,但以下情形例外:(領(lǐng)域模型 的相關(guān)命名)DO / BO / DTO / VO 等。
    正例:MarcoPolo / UserDO / XmlService / TcpUdpDeal / TaPromotion
    反例:macroPolo / UserDo / XMLService / TCPUDPDeal / TAPromotion

  3. 【強(qiáng)制】方法名休讳、參數(shù)名讲婚、成員變量、局部變量都統(tǒng)一使用 lowerCamelCase 風(fēng)格俊柔,必須遵從 駝峰形式筹麸。
    正例: localValue / getHttpMessage() / inputUserId

  4. 【強(qiáng)制】常量命名全部大寫,單詞間用下劃線隔開雏婶,力求語義表達(dá)完整清楚物赶,不要嫌名字長。
    正例: MAX_STOCK_COUNT 反例: MAX_COUNT

  5. 【強(qiáng)制】中括號是數(shù)組類型的一部分留晚,數(shù)組定義如下:String[] args;
    反例:使用 String args[]的方式來定義酵紫。

  6. 【強(qiáng)制】POJO 類中布爾類型的變量,都不要加 is错维,否則部分框架解析會引起序列化錯誤奖地。
    反例:定義為基本數(shù)據(jù)類型 Boolean isSuccess;的屬性赋焕,它的方法也是 isSuccess()参歹,RPC 框架在反向解析的時候,“以為”對應(yīng)的屬性名稱是 success隆判,導(dǎo)致屬性獲取不到犬庇,進(jìn)而拋出異常。

  7. 【強(qiáng)制】包名統(tǒng)一使用小寫侨嘀,點(diǎn)分隔符之間有且僅有一個自然語義的英語單詞臭挽。包名統(tǒng)一使用 單數(shù)形式,但是類名如果有復(fù)數(shù)含義咬腕,類名可以使用復(fù)數(shù)形式欢峰。
    正例: 應(yīng)用工具類包名為 com.alibaba.open.util、類名為 MessageUtils(此規(guī)則參考 spring 的框架結(jié)構(gòu))

  8. 【推薦】接口類中的方法和屬性不要加任何修飾符號(public 也不要加),保持代碼的簡潔 性赤赊,并加上有效的 Javadoc 注釋。盡量不要在接口里定義變量煞赢,如果一定要定義變量抛计,肯定是 與接口方法相關(guān),并且是整個應(yīng)用的基礎(chǔ)常量照筑。
    正例:接口方法簽名:void f(); 接口基礎(chǔ)常量表示:String COMPANY = "alibaba";
    反例:接口方法定義:public abstract void f();
    說明:JDK8 中接口允許有默認(rèn)實現(xiàn)吹截,那么這個 default 方法,是對所有實現(xiàn)類都有價值的默 認(rèn)實現(xiàn)凝危。

  9. 【參考】枚舉類名建議帶上 Enum 后綴波俄,枚舉成員名稱需要全大寫,單詞間用下劃線隔開蛾默。
    說明:枚舉其實就是特殊的常量類懦铺,且構(gòu)造方法被默認(rèn)強(qiáng)制是私有。
    正例:枚舉名字:DealStatusEnum支鸡,成員名稱:SUCCESS / UNKOWN_REASON冬念。

(二)格式規(guī)約

  1. 【強(qiáng)制】大括號的使用約定。如果是大括號內(nèi)為空牧挣,則簡潔地寫成{}即可急前,不需要換行;如果 是非空代碼塊則:
    1) 左大括號前不換行瀑构。
    2) 左大括號后換行裆针。
    3) 右大括號前換行。
    4) 右大括號后還有 else 等代碼則不換行寺晌;表示終止的右大括號后必須換行世吨。

  2. 【強(qiáng)制】 左小括號和右邊相鄰字符之間不出現(xiàn)空格;同樣折剃,右小括號和左邊相鄰字符之間也 不出現(xiàn)空格另假。詳見第 5 條下方正例提示。

  3. 【強(qiáng)制】if/for/while/switch/do 等保留字與小括號之間都必須加空格怕犁。

  4. 【強(qiáng)制】任何運(yùn)算符左右必須加一個空格边篮。 說明:運(yùn)算符包括賦值運(yùn)算符=、邏輯運(yùn)算符&&奏甫、加減乘除符號戈轿、三目運(yùn)算符等。

  5. 【強(qiáng)制】縮進(jìn)采用 4 個空格阵子,禁止使用 tab 字符思杯。
    說明:如果使用 tab 縮進(jìn),必須設(shè)置 1 個 tab 為 4 個空格。IDEA 設(shè)置 tab 為 4 個空格時色乾, 請勿勾選 Use tab character誊册;而在 eclipse 中,必須勾選 insert spaces for tabs暖璧。 設(shè)置方法請見本文附錄案怯。
    正例: (涉及 1-5 點(diǎn))

public static void main(String[] args) {
      // 縮進(jìn) 4 個空格
      String say = "hello";
      // 運(yùn)算符的左右必須有一個空格
      int flag = 0;
     // 關(guān)鍵詞 if 與括號之間必須有一個空格,括號內(nèi)的 f 與左括號澎办,0 與右括號不需要空格
      if (flag == 0) {
          System.out.println(say);
      } 
      // 左大括號前加空格且不換行嘲碱;左大括號后換行
      if (flag == 1) {
          System.out.println("world");
      // 右大括號前換行,右大括號后有 else局蚀,不用換行    
      } else {            System.out.println("ok");
      // 在右大括號后直接結(jié)束麦锯,則必須換行
      }  
} 
  1. 【強(qiáng)制】單行字符數(shù)限制不超過 120 個,超出需要換行琅绅,換行時遵循如下原則:
    1) 第二行相對第一行縮進(jìn) 4 個空格扶欣,從第三行開始,不再繼續(xù)縮進(jìn)千扶,參考示例宵蛀。
    2) 運(yùn)算符與下文一起換行。
    3) 方法調(diào)用的點(diǎn)符號與下文一起換行县貌。
    4) 在多個參數(shù)超長术陶,逗號后進(jìn)行換行。
    5) 在括號前不要換行煤痕,見反例梧宫。
    正例:
StringBuffer sb = new StringBuffer();
  //超過 120 個字符的情況下,換行縮進(jìn) 4 個空格摆碉,并且方法前的點(diǎn)符號一起換行
sb.append("zi").append("xin")...    
    .append("huang")...  
    .append("huang")...  
    .append("huang");

反例:

 StringBuffer sb = new StringBuffer();
  //超過 120 個字符的情況下塘匣,不要在括號前換行  
sb.append("zi").append("xin")...append
      ("huang");   
//參數(shù)很多的方法調(diào)用可能超過 120 個字符,不要在逗號前換行
  method(args1, args2, args3, ...     
     , argsX); 
  1. 【強(qiáng)制】方法參數(shù)在定義和傳入時巷帝,多個參數(shù)逗號后邊必須加空格忌卤。
    正例:下例中實參的"a",后邊必須要有一個空格。
   method("a", "b", "c");   
  1. 【強(qiáng)制】IDE 的 text file encoding 設(shè)置為 UTF-8; IDE 中文件的換行符使用 Unix 格式楞泼, 不要使用 windows 格式驰徊。 設(shè)置方法請見本文附錄
  2. 【推薦】方法體內(nèi)的執(zhí)行語句組、變量的定義語句組堕阔、不同的業(yè)務(wù)邏輯之間或者不同的語義 之間插入一個空行棍厂。相同業(yè)務(wù)邏輯和語義之間不需要插入空行。

附錄

eclipse把Tab設(shè)置為4個空格

  1. 點(diǎn)擊 window->preference-,依次選擇 General->Editors->Text Editors,選中右側(cè)的 insert space for tabs;如下圖所示超陆,保存牺弹。
    <div align = center>


    圖1-1

    </div>

  2. 點(diǎn)擊 window->preference-,依次選擇 Java->code style ->formatter,點(diǎn)擊右側(cè)的editor,選則左側(cè) tab policy的值為spaces only,確定,應(yīng)用保存即可张漂,如下圖所示:
    <div align = center>

    圖1-2

    </div>
    若出現(xiàn)應(yīng)用Apply按鈕為灰色的情況晶默,需要回到上一步,點(diǎn)擊new按鈕航攒,根據(jù)當(dāng)前的樣式重新生成一個新的樣式并保存荤胁,重復(fù)第2步,編輯該樣式即可屎债,如下圖:
    <div align = center>
    圖1-3

    </div>

IDE 的 text file encoding設(shè)置

Window -> Preferences -> General -> Workspace : Text file encoding
<div align = center>

圖2-1

</div>

本文摘抄自阿里巴巴Java開發(fā)手冊

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市垢油,隨后出現(xiàn)的幾起案子盆驹,更是在濱河造成了極大的恐慌,老刑警劉巖滩愁,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件躯喇,死亡現(xiàn)場離奇詭異,居然都是意外死亡硝枉,警方通過查閱死者的電腦和手機(jī)廉丽,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來妻味,“玉大人正压,你說我怎么就攤上這事≡鹎颍” “怎么了焦履?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長雏逾。 經(jīng)常有香客問我嘉裤,道長,這世上最難降的妖魔是什么栖博? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任屑宠,我火速辦了婚禮,結(jié)果婚禮上仇让,老公的妹妹穿的比我還像新娘典奉。我一直安慰自己,他們只是感情好丧叽,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布秋柄。 她就那樣靜靜地躺著,像睡著了一般蠢正。 火紅的嫁衣襯著肌膚如雪骇笔。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天,我揣著相機(jī)與錄音笨触,去河邊找鬼懦傍。 笑死,一個胖子當(dāng)著我的面吹牛芦劣,可吹牛的內(nèi)容都是我干的粗俱。 我是一名探鬼主播,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼虚吟,長吁一口氣:“原來是場噩夢啊……” “哼寸认!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起串慰,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤偏塞,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后邦鲫,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體灸叼,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年庆捺,在試婚紗的時候發(fā)現(xiàn)自己被綠了古今。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡滔以,死狀恐怖捉腥,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情你画,我是刑警寧澤但狭,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布,位于F島的核電站撬即,受9級特大地震影響立磁,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜剥槐,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一唱歧、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧粒竖,春花似錦颅崩、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至朽砰,卻和暖如春尖滚,著一層夾襖步出監(jiān)牢的瞬間喉刘,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工漆弄, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留睦裳,地道東北人。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓撼唾,卻偏偏與公主長得像廉邑,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子倒谷,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,933評論 2 355

推薦閱讀更多精彩內(nèi)容