一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - 教妹學Java:Java命名約定

教妹學Java:Java命名約定

2020-11-18 23:01沉默王二 Java教程

由于互聯網上的域名是不會重復的,所以多數開發人員采用自己公司(或者個人博客)在互聯網上的域名稱作為包的唯一前綴。比如我文章中出現的代碼示例的包名就是 package com.itwanger。

教妹學Java:Java命名約定

就有同學留言說“妹妹大一就開始學習 Java 了,有點厲害啊。”我只能說,要對妹妹負責,就必須得趁早,因為生意經有這么一句話:

人無我有,人有我好,人好我早,人多我早。

這句話用在生意上合適,用在學習上也是再合適不過了。當別人都不懂一門新技術的時候,你懂,那么恭喜你,你已經遙遙領先了;當別人也懂了,你比他精通,那么你就是牛逼;當別人也精通了,你比他精通的早,還是有優勢,對吧?

強調一下,《教妹學 Java》面向的是零基礎的 Java 愛好者,我希望能幫助同學們輕松邁進編程世界的大門,為后續的深入學習打下堅實的基礎。

“二哥,Java 中的命名約定都有哪些呢?”三妹的臉上泛著甜甜的笑容,她開始對接下來要學習的內容充滿期待了,這正是我感到欣慰的地方。

“對于我們中國人來說,名字也是有講究的,比如說我叫沉默王二,你就叫沉默王三,哈哈。”我笑著對三妹說。

命名約定決定我們使用什么樣的標識符來命名包、類、字段、方法等等,雖然這個規則不是強制的,可以遵守,也可以不遵守,但如果不遵守的話,就會帶來很多不必要的麻煩。

起個好的名字,就好像穿一件得體的衣服,呈現給人的用戶體驗是完全不一樣的。

好的命名可以讓你的代碼更易讀,包括你自己和你的小伙伴,看一眼,不用想太多,就能明白代碼是干嘛的。

拿我這個筆名“沉默王二”來舉例吧,讀起來我就覺得朗朗上口,讀者看到這個筆名就知道我是一個什么樣的人——對不熟的人保持沉默,對熟的人妙語連珠,哈哈。

01、包(package)

包的命名應該遵守以下規則:

  • 應該全部是小寫字母
  • 點分隔符之間有且僅有一個自然語義的英語單詞
  • 包名統一使用單數形式,比如說 com.itwanger.util 不能是 com.itwanger.utils
  • 在最新的 Java 編程規范中,要求開發人員在自己定義的包名前加上唯一的前綴。由于互聯網上的域名是不會重復的,所以多數開發人員采用自己公司(或者個人博客)在互聯網上的域名稱作為包的唯一前綴。比如我文章中出現的代碼示例的包名就是 package com.itwanger。

02、類(class)

類的命名應該遵守以下規則:

  • 必須以大寫字母開頭
  • 最好是一個名詞,比如說 System
  • 類名使用 UpperCamelCase(駝峰式命名)風格
  • 盡量不要省略成單詞的首字母,但以下情形例外:DO/BO/DTO/VO/AO/ PO / UID 等

教妹學Java:Java命名約定

另外,如果是抽象類的話,使用 Abstract 或 Base 開頭;如果是異常類的話,使用 Exception 結尾;如果是測試類的話,使用 Test 結尾。

03、接口(interface)

接口的命名應該遵守以下規則:

  • 必須以大寫字母開頭
  • 最好是一個形容詞,比如說 Runnable
  • 盡量不要省略成單詞的首字母

來看個例子:

interface Printable {} 

接口和實現類之間也有一些規則:

  • 實現類用 Impl 的后綴與接口區別,比如說 CacheServiceImpl 實現 CacheService 接口
  • 或者,AbstractTranslator 實現 Translatable 接口

04、字段(field)和變量(variable)

字段和變量的命名應該遵守以下規則:

  • 必須以小寫字母開頭
  • 可以包含多個單詞,第一個單詞的首字母小寫,其他的單詞首字母大寫,比如說 firstName
  • 最好不要使用單個字符,比如說 int a,除非是局部變量
  • 類型與中括號緊挨相連來表示數組,比如說 int[] arrayDemo,main 方法中字符串數組參數不應該寫成 String args[]
  • POJO 類中的任何布爾類型的變量,都不要加 is 前綴,否則部分框架解析會引起序列化錯誤,我自己知道的有 fastjson
  • 避免在子類和父類的成員變量之間、或者不同代碼塊的局部變量之間采用完全相同的命名,使可理解性降低。子類、父類成員變量名相同,即使是 public 類型的變量也能夠通過編譯,另外,局部變量在同一方法內的不同代碼塊中同名也是合法的,這些情況都要避免。

反例:

public class ConfusingName { 

    public int stock; 

 

    // 非 setter/getter 的參數名稱,不允許與本類成員變量同名 

    public void get(String alibaba) { 

        if (condition) { 

            final int money = 666; 

// ... 

        } 

        for (int i = 0; i < 10; i++) { 

// 在同一方法體中,不允許與其它代碼塊中的 money 命名相同 final int money = 15978; 

// ... 

        } 

    } 

 

class Son extends ConfusingName { 

// 不允許與父類的成員變量名稱相同 public int stock; 

05、常量(constant)

常量的命名應該遵守以下規則:

  • 應該全部是大寫字母
  • 可以包含多個單詞,單詞之間使用“_”連接,比如說 MAX_PRIORITY,力求語義表達完整清楚,不要嫌名字長
  • 可以包含數字,但不能以數字開頭

來看個例子:

static final int MIN_AGE = 18;   

06、方法(method)

方法的命名應該遵守以下規則:

  • 必須以小寫字母開頭
  • 最好是一個動詞,比如說 print()
  • 可以包含多個單詞,第一個單詞的首字母小寫,其他的單詞首字母大寫,比如說 actionPerformed()

來看個例子:

void writeBook(){} 

Service/DAO 層的方法命名規約:

  • 獲取單個對象的方法用 get 做前綴
  • 獲取多個對象的方法用 list 做前綴,復數結尾,如:listObjects
  • 獲取統計值的方法用 count 做前綴
  • 插入的方法用 save/insert 做前綴
  • 刪除的方法用 remove/delete 做前綴
  • 修改的方法用 update 做前綴

07、總結

除了以上這些規則以外,還有一些共同的規則需要遵守,比如說:

  • 代碼中的命名均不能以下劃線或美元符號開始,也不能以下劃線或美元符號結束。反例:_name / __name / $name / name_ / name$ / name__
  • 所有編程相關的命名嚴禁使用拼音與英文混合的方式,更不允許直接使用中文的方式。反例:DaZhePromotion [打折] / getPingfenByName() [評分] / String fw[福娃] / int 某變量 = 3
  • 代碼和注釋中都要避免使用任何語言的種族歧視性詞語。反例:RIBENGUIZI / Asan / blackList / whiteList / slave
  • 方法名、參數名、成員變量、局部變量都統一使用 lowerCamelCase 風格。
  • 杜絕完全不規范的縮寫,避免望文不知義。反例:AbstractClass “縮寫”成 AbsClass;condition “縮寫”成 condi;Function 縮寫”成 Fu,此類隨意縮寫嚴重降低了代碼的可閱讀性。
  • 為了達到代碼自解釋的目標,任何自定義編程元素在命名時,使用盡量完整的單詞組合來表達。
  • 在常量與變量的命名時,表示類型的名詞放在詞尾,以提升辨識度。正例:startTime / workQueue / nameList / TERMINATED_THREAD_COUNT
  • 如果模塊、接口、類、方法使用了設計模式,在命名時需體現出具體模式。將設計模式體現在名字中,有利于閱讀者快速理解架構設計理念。比如說:public class OrderFactory;public class LoginProxy;public class ResourceObserver;
  • 枚舉類名帶上 Enum 后綴,枚舉成員名稱需要全大寫,單詞間用下劃線隔開。枚舉其實就是特殊的常量類,且構造方法被默認強制是私有。比如說:枚舉名字為 ProcessStatusEnum 的成員名稱:SUCCESS / UNKNOWN_REASON。

“好了,三妹,關于 Java 中的命名約定就先說這么多吧,你平常在寫代碼的時候注意一下,養成好習慣。”轉動了一下僵硬的脖子后,我對三妹說。

“好的,二哥,你辛苦了,原來命名約定還有這么多說法,真的是你知道的越多,你不知道的越多啊。”

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 冰漪丰满大乳人体图片欣赏 | 无限资源在线观看8 | 婷婷久久综合 | 给我免费的视频在线观看 | 亚洲AV人无码综合在线观看蜜桃 | 精品亚洲永久免费精品 | 四虎成人免费观看在线网址 | 青青草原影院 | 亚洲高清在线视频 | 黑人video粗暴日本 | 男人猛进女人屁股免费 | 91中文字幕yellow字幕网 | 69japanese日本100 6969精品视频在线观看 | 男人使劲躁女人视频免费 | 亚洲免费在线视频 | 欧美肥bb| 国产麻豆精品入口在线观看 | 美女的让男人桶爽30分钟的 | 精品一区二区三区五区六区 | 天天操免费视频 | 亚洲 欧美 清纯 校园 另类 | 精品一久久香蕉国产线看播放 | 私人家庭影院5577 | 出a级黑粗大硬长爽猛视频 吃胸膜奶视频456 | 色综合久久天天综合观看 | 日本中文字幕不卡在线一区二区 | 亚洲成年人专区 | a看片| 国产一区二区精品久久 | 国产精品国产色综合色 | 亚洲天天做夜夜做天天欢 | 欧美a级完整在线观看 | 成人在线免费播放 | tube69中国露脸 | wwwav视频| 亚洲精品国产在线网站 | а天堂中文最新版在线 | 精品视频久久久久 | 无码乱人伦一区二区亚洲一 | 轻轻色在线视频中文字幕 | 欧美粗黑巨大gay |