返回頂部
關(guān)閉軟件導(dǎo)航
位置:首頁 > 資訊 > 電商資訊>為什么阿里工程師代碼寫的好看看他的代碼規(guī)范就知道了
為什么阿里工程師代碼寫的好看看他的代碼規(guī)范就知道了

本文主要講解阿里JAVA開發(fā)手冊中比較重要的設(shè)計規(guī)范,這些重要的設(shè)計規(guī)范有助于我們改進(jìn)自己的代碼,提升系統(tǒng)的系統(tǒng)的性能。

曾經(jīng)與一位從阿里出來的Java工程師一起工作過一段時間,他的技術(shù)說不上非常厲害,但是,他的代碼寫的的非常好,凡是他做的功能很少出現(xiàn)Bug。我就很好奇,于是經(jīng)常向他請教一些代碼設(shè)計的原則,然后他告訴了我阿里Java手冊。并且,他將這個手冊進(jìn)行了修改,也成為了我司Java程序員的開發(fā)手冊。這篇文章就讓我們看一看這個手冊中比較重要的原則。

代碼中的命名均不能以下劃線或美元符號開始,也不能以下劃線或美元符號結(jié)束。

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

類型與中括號緊挨相連來表示數(shù)組。

正例:定義整形數(shù)組int[]arrayDemo;反例:在main參數(shù)中,使用Stringargs[]來定義。

POJO類中布爾類型變量都不要加is前綴,否則部分框架解析會引起序列化錯誤。

說明:表達(dá)是與否的值采用is_xxx的命名方式,所以,需要在設(shè)置從is_xxx到xxx的映射關(guān)系。

反例:定義為基本數(shù)據(jù)類型BooleanisDeleted的屬性,它的方法也是isDeleted(),RPC框架在反向解析的時候,“誤以為”對應(yīng)的屬性名稱是deleted,導(dǎo)致屬性獲取不到,進(jìn)而拋出異常。

在常量與變量的命名時,表示類型的名詞放在詞尾,以提升辨識度。

正例:startTime/workQueue/nameList/TERMINATED_THREAD_COUNT

反例:startedAt/QueueOfWork/listName/COUNT_TERMINATED_THREAD

接口類中的方法和屬性不要加任何修飾符號(public也不要加),保持代碼的簡潔性,并加上有效的Javadoc注釋。盡量不要在接口里定義變量,假如一定要定義變量,肯定是與接口方法相關(guān),并且是整個應(yīng)用的基礎(chǔ)常量。

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

接口基礎(chǔ)常量StringCOMPANY="alibaba";

反例:接口方法定義publicabstractvoidf();

說明:JDK8中接口答應(yīng)有默認(rèn)實現(xiàn),那么這個default方法,是對所有實現(xiàn)類都有價值的默認(rèn)實現(xiàn)。

枚舉類名帶上Enum后綴,枚舉成員名稱需要全大寫,單詞間用下劃線隔開。

說明:枚舉其實就是尤其的類,域成員均為常量,且構(gòu)造方法被默認(rèn)強制是私有。

正例:枚舉名字為ProcessStatusEnum的成員名稱:SUCCESS/UNKNOWN_REASON。

為什么阿里工程師代碼寫的好看看他的代碼規(guī)范就知道了1

各層命名規(guī)約:

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

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

2)獲取多個對象的方法用list做前綴,復(fù)數(shù)形式結(jié)尾如:listObjects。3)獲取統(tǒng)計值的方法用count做前綴。

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

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

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

B)領(lǐng)域模型命名規(guī)約

1)數(shù)據(jù)對象:xxxDO,xxx即為數(shù)據(jù)表名。

2)數(shù)據(jù)傳輸對象:xxxDTO,xxx為業(yè)務(wù)領(lǐng)域相關(guān)的名稱。

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

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

不答應(yīng)任何魔法值(即未經(jīng)預(yù)先定義的常量)直接出現(xiàn)在代碼中。

為什么阿里工程師代碼寫的好看看他的代碼規(guī)范就知道了2

反例:Stringkey="Id#taobao_"+tradeId;

cache.put(key,value);

cache.put(key,value);

避免通過一個類的對象引用訪問此類的靜態(tài)變量或靜態(tài)方法,無謂增加編譯器解析成本,直接用類名來訪問即可。

相同參數(shù)類型,相同業(yè)務(wù)含義,才可以使用Java的可變參數(shù),避免使用Object。

說明:可變參數(shù)必須放置在參數(shù)列表的很后。(提倡同學(xué)們盡量不用可變參數(shù)編程)

正例:publicListlistUsers(Stringtype,Long...ids){...}

所有整型包裝類對象之間值的比較,全部使用equals方法比較。

說明:對于Integervar=?在-128至127范圍內(nèi)的賦值,Integer對象是在IntegerCache.cache產(chǎn)生,會復(fù)用已有對象,這個區(qū)間內(nèi)的Integer值可以直接使用==進(jìn)行判定,但是這個區(qū)間之外的所有數(shù)據(jù),都會在堆上產(chǎn)生,并不會復(fù)用已有對象,這是一個大坑,推薦使用equals方法進(jìn)行判定。

關(guān)于基本數(shù)據(jù)類型與包裝數(shù)據(jù)類型的使用標(biāo)準(zhǔn)如下:

1)【強制】所有的POJO類屬性必須使用包裝數(shù)據(jù)類型。

2)【強制】RPC方法的返回值和參數(shù)必須使用包裝數(shù)據(jù)類型。3)【推薦】所有的局部變量使用基本數(shù)據(jù)類型。

說明:POJO類屬性沒有初值是提醒使用者在需要使用時,必須自己顯式地進(jìn)行賦值,任何NPE問題,或者入庫檢查,都由使用者來保證。

正例:數(shù)據(jù)庫的查詢結(jié)果可能是null,因為自動拆箱,用基本數(shù)據(jù)類型接收有NPE風(fēng)險。

反例:比如顯示成交總額漲跌情況,即正負(fù)x%,x為基本數(shù)據(jù)類型,調(diào)用的RPC服務(wù),調(diào)用不成功時,返回的是默認(rèn)值,頁面顯示為0%,這是不合理的,應(yīng)該顯示成中劃線。所以包裝數(shù)據(jù)類型的null值,能夠表示額外的信息,如:遠(yuǎn)程調(diào)用失敗,異常退出。

POJO類必須寫toString方法。

使用IDE中的工具:source>generatetoString時,假如繼續(xù)了另一個POJO類,注重在前面加一下super.toString。

說明:在方法執(zhí)行拋出異常時,可以直接調(diào)用POJO的toString()方法打印其屬性值,便于排查問題。

關(guān)于hashCode和equals的處理,遵循如下規(guī)則:

1)只要覆寫equals,就必須覆寫hashCode。

2)因為Set存儲的是不重復(fù)的對象,依據(jù)hashCode和equals進(jìn)行判定,所以Set存儲的對象必須覆寫這兩個方法。

3)假如自定義對象作為Map的鍵,那么必須覆寫hashCode和equals。

說明:String已覆寫hashCode和equals方法,所以我們可以愉快地使用String對象作為key來使用。

線程資源必須通過線程池提供,不答應(yīng)在應(yīng)用中自行顯式創(chuàng)建線程。

說明:線程池的好處是減少在創(chuàng)建和銷毀線程上所消耗的時間以及系統(tǒng)資源的開銷,解決資源不足的問題。假如不使用線程池,有可能造成系統(tǒng)創(chuàng)建大量同類線程而導(dǎo)致消耗完內(nèi)存或者“過度切換”的問題。

線程池不答應(yīng)使用Executors去創(chuàng)建,而是通過ThreadPoolExecutor的方式,這樣的處理方式讓寫的同學(xué)更加明確線程池的運行規(guī)則,規(guī)避資源耗盡的風(fēng)險。

以上規(guī)范在設(shè)計代碼中,是比較重要的原則。假如編寫代碼的過程中,可以依照以上原則,那代碼的可讀性和可維護(hù)性將大大提升

如果您覺得 為什么阿里工程師代碼寫的好看看他的代碼規(guī)范就知道了 這篇文章對您有用,請分享給您的好友,謝謝
文章地址:http://www.brucezhang.com/article/online/6557.html
解放雙手無盡可能,有問題添加天線貓微信
主站蜘蛛池模板: 精品无码成人片一区二区98| www亚洲欲色成人久久精品| 国产成人精品综合久久久| 国产成人精品福利网站在线观看| 成人一级黄色大片| 国产成人高清精品免费鸭子| 免费网站看v片在线成人国产系列 免费观看一级成人毛片 | 成人影片麻豆国产影片免费观看 | 国产成人AV免费观看| 激情婷婷成人亚洲综合| 国产成人精品福利色多多| 亚洲AV成人中文无码专区| 成人动漫在线视频| 久久久久成人精品一区二区| 成人动漫视频在线| 久久久久99精品成人片| 成人嗯啊视频在线观看| 亚洲精品成人网久久久久久| 欧美成人免费观看的| 亚洲国产成人av网站| 国产成人愉拍精品| 国产成人综合亚洲欧美在| 色噜噜狠狠色综合成人网| 四虎国产成人永久精品免费| 国产成人综合日韩精品婷婷九月| 欧美成人全部费免网站| 69国产成人精品午夜福中文| 国产一级成人毛片| 成人亚洲成人影院| 成人黄18免费视频| 欧美色成人tv在线播放| 亚洲va在线va天堂成人| 国产69久久精品成人看小说| 国产成人综合在线视频| 成人免费无毒在线观看网站| 日韩成人无码一区二区三区| 8x成人永久免费视频| 欧美成人看片黄a免费看| 久久久久亚洲av成人无码| 麻豆成人精品国产免费| 欧美成人免费公开播放欧美成人免费一区在线播放 |