爲什麼阿里強制 boolean 類型變量不能使用 is 開頭?

背景

平時工作中大家經常使用到boolean以及Boolean類型的數據,前者是基本數據類型,後者是包裝類,爲什麼不推薦使用isXXX來命名呢?到底是用基本類型的數據好呢還是用包裝類好呢?

例子

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;
    }    

其實阿里巴巴發佈的java開發手冊中就寫明瞭,強制規定,布爾類型的數據,無論是boolean還是Boolean都不準使用isXXX來命名 在這裏插入圖片描述

  • 對於非boolean類型的參數,getter和setter方法命名的規範是以get和set開頭
  • 對於boolean類型的參數,setter方法是以set開頭,但是getter方法命名的規範是以is開頭
  • 包裝類自動生成的getter和setter方法的名稱都是getXXX()和setXXX()

1.其實javaBeans規範中對這些均有相應的規定,基本數據類型的屬性,其getter和setter方法是getXXX()和setXXX,但是對於基本數據中布爾類型的數據,又有一套規定,其getter和setter方法是isXXX()和setXXX。但是包裝類型都是以get開頭

2.這種方式在某些時候是可以正常運行的,但是在一些rpc框架裏面,當反向解析讀取到isSuccess()方法的時候,rpc框架會“以爲”其對應的屬性值是success,而實際上其對應的屬性值是isSuccess,導致屬性值獲取不到,從而拋出異常。

總結

1、boolean類型的屬性值不建議設置爲is開頭,否則會引起rpc框架的序列化異常。

2、如果強行將IDE自動生成的isSuccess()方法修改成getSuccess(),也能獲取到Success屬性值,若兩者並存,則之後通過getSuccess()方法獲取Success屬性值。

工作中使用基本類型的數據好還是包裝類好

咱們舉個例子,一個計算盈利的系統,其盈利比例有正有負,若使用了基本類型bouble定義了數據,當RPC調用時,若出現了問題,本來應該返回錯誤的,但是由於使用了基本類型,返回了0.0,系統會認爲沒有任何問題,今年收支平衡,而不會發現其實是出現了錯誤。

若使用了包裝數據類型Double,當RPC調用失敗時,會返回null,這樣直接就能看到出現問題了,而不會因爲默認值的問題影響判斷。

其實阿里java開發手冊中對於這個也有強制規定: 在這裏插入圖片描述 因此,這裏建議大家POJO中使用包裝數據類型,局部變量使用基本數據類型。

來源:blog.csdn.net/belongtocode/article/details/100635246

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章