為什么阿里強制 boolean 類型變量不能使用 is 開頭?
點擊“藍字”,關(guān)注,置頂公眾號
每日技術(shù)干貨,第一時間送達!
1
背景
平時工作中大家經(jīng)常使用到boolean以及Boolean類型的數(shù)據(jù),前者是基本數(shù)據(jù)類型,后者是包裝類,為什么不推薦使用isXXX來命名呢?到底是用基本類型的數(shù)據(jù)好呢還是用包裝類好呢?
例子
1.其他非boolean類型
private?String?isHot;
public?String?getIsHot() {
????????return?isHot;
}2.boolean類型
private?boolean?isHot;
????public?boolean?isHot()?{
????????return?isHot;
}3.包裝類型
private?Boolean?isHot;
public?Boolean?getHot() {
????????return?isHot;
}4.不以is開頭
private?boolean?hot;
????public?boolean?isHot()?{
????????return?hot;
}5.包裝類型
private?Boolean?hot;
????public?Boolean?getHot() {
????????return?hot;
}其實阿里巴巴發(fā)布的java開發(fā)手冊中就寫明了,強制規(guī)定,布爾類型的數(shù)據(jù),無論是boolean還是Boolean都不準使用isXXX來命名

對于非boolean類型的參數(shù),getter和setter方法命名的規(guī)范是以get和set開頭
對于boolean類型的參數(shù),setter方法是以set開頭,但是getter方法命名的規(guī)范是以is開頭
包裝類自動生成的getter和setter方法的名稱都是getXXX()和setXXX()
其實javaBeans規(guī)范中對這些均有相應(yīng)的規(guī)定,基本數(shù)據(jù)類型的屬性,其getter和setter方法是getXXX()和setXXX,但是對于基本數(shù)據(jù)中布爾類型的數(shù)據(jù),又有一套規(guī)定,其getter和setter方法是isXXX()和setXXX。但是包裝類型都是以get開頭。
這種方式在某些時候是可以正常運行的,但是在一些rpc框架里面,當反向解析讀取到isSuccess()方法的時候,rpc框架會“以為”其對應(yīng)的屬性值是success,而實際上其對應(yīng)的屬性值是isSuccess,導致屬性值獲取不到,從而拋出異常。
1
總結(jié)
1、boolean類型的屬性值不建議設(shè)置為is開頭,否則會引起rpc框架的序列化異常。
2、如果強行將IDE自動生成的isSuccess()方法修改成getSuccess(),也能獲取到Success屬性值,若兩者并存,則之后通過getSuccess()方法獲取Success屬性值。
工作中使用基本類型的數(shù)據(jù)好還是包裝類好
咱們舉個例子,一個計算盈利的系統(tǒng),其盈利比例有正有負,若使用了基本類型bouble定義了數(shù)據(jù),當RPC調(diào)用時,若出現(xiàn)了問題,本來應(yīng)該返回錯誤的,但是由于使用了基本類型,返回了0.0,系統(tǒng)會認為沒有任何問題,今年收支平衡,而不會發(fā)現(xiàn)其實是出現(xiàn)了錯誤。
若使用了包裝數(shù)據(jù)類型Double,當RPC調(diào)用失敗時,會返回null,這樣直接就能看到出現(xiàn)問題了,而不會因為默認值的問題影響判斷。
其實阿里java開發(fā)手冊中對于這個也有強制規(guī)定:

因此,這里建議大家POJO中使用包裝數(shù)據(jù)類型,局部變量使用基本數(shù)據(jù)類型。
來源:https://blog.csdn.net/belongtocode/article/details/100635246
