自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

為什么阿里巴巴要求 POJO 中不能使用基本數(shù)據(jù)類型?

開發(fā) 前端
如果由于計(jì)費(fèi)系統(tǒng)異常,他可能會返回個默認(rèn)值,如果這個字段是Double類型的話,該默認(rèn)值為null,如果該字段是double類型的話,該默認(rèn)值為0.0。

在《阿里巴巴Java開發(fā)手冊》中,對于POJO中如何選擇變量的類型以及 RPC 接口中的返回值類型也有著一些規(guī)定:

這里強(qiáng)制要求使用包裝類型,原因是什么呢?

我們來看一段簡單的代碼:

     /**

* @author Hollis

*/

public class BooleanMainTest {

public static void main(String[] args) {

Model model1 = new Model();

System.out.println("default model : " + model1);

}

}

class Model {

/**

* 定一個Boolean類型的success成員變量

*/

private Boolean success;

/**

* 定一個boolean類型的failure成員變量

*/

private boolean failure;

/**

* 覆蓋toString方法,使用Java 8 的StringJoiner

*/

@Override

public String toString() {

return new StringJoiner(", ", Model.class.getSimpleName() + "[", "]")

.add("success=" + success)

.add("failure=" + failure)

.toString();

}

}

以上代碼輸出結(jié)果為:

default model : Model[success=null, failure=false]

可以看到,當(dāng)我們沒有設(shè)置Model對象的字段的值的時候,Boolean類型的變量會設(shè)置默認(rèn)值為null,而boolean類型的變量會設(shè)置默認(rèn)值為false。

即Boolean對象的默認(rèn)值是null,boolean基本數(shù)據(jù)類型的默認(rèn)值是false。

也就是說,包裝類型的默認(rèn)值都是null,而基本數(shù)據(jù)類型的默認(rèn)值是一個固定值,如boolean是false,byte、short、int、long是0,float是0.0f等;

我們再舉一個扣費(fèi)的例子,我們做一個扣費(fèi)系統(tǒng),扣費(fèi)時需要從外部的定價系統(tǒng)中通過 RPC 請求讀取一個費(fèi)率的值,我們預(yù)期該接口的返回值中會包含一個浮點(diǎn)型的費(fèi)率字段。當(dāng)我們?nèi)〉竭@個值得時候就使用公式:金額*費(fèi)率=費(fèi)用 進(jìn)行計(jì)算,計(jì)算結(jié)果進(jìn)行劃扣。

如果由于計(jì)費(fèi)系統(tǒng)異常,他可能會返回個默認(rèn)值,如果這個字段是Double類型的話,該默認(rèn)值為null,如果該字段是double類型的話,該默認(rèn)值為0.0。

如果扣費(fèi)系統(tǒng)對于該費(fèi)率返回值沒做特殊處理的話,拿到null值進(jìn)行計(jì)算會直接報錯,阻斷程序。拿到0.0可能就直接進(jìn)行計(jì)算,得出接口為0后進(jìn)行扣費(fèi)了。這種異常情況就無法被感知。

有人說,那我可以對0.0做特殊判斷,如果是0一樣可以阻斷報錯啊。但是,這時候就會產(chǎn)生一個問題,如果允許費(fèi)率是0的場景又怎么處理呢?

所以,使用基本數(shù)據(jù)類型只會讓方案越來越復(fù)雜,坑越來越多。

這種使用包裝類型定義變量的方式,通過異常來阻斷程序,進(jìn)而可以被識別到這種線上問題。如果使用基本數(shù)據(jù)類型的話,系統(tǒng)可能不會報錯,進(jìn)而認(rèn)為無異常。

當(dāng)然,以上的選擇是針對一些電商、支付、金融等場景,可以犧牲暫時的可用性的場景,如果是對于某些軟件系統(tǒng),可以容忍數(shù)據(jù)不準(zhǔn),但是不能系統(tǒng)不可用的情況要另當(dāng)別論。

以上,就是要求在POJO和RPC的返回值中使用包裝類型的原因。

責(zé)任編輯:武曉燕 來源: Hollis
相關(guān)推薦

2021-10-11 09:32:40

包裝類型屬性

2019-06-26 07:54:53

ArrayListsubList源碼

2020-09-14 09:47:56

Java開發(fā)類型

2018-10-16 15:34:17

阿里巴巴Apache Flin大數(shù)據(jù)

2021-08-04 17:20:30

阿里巴巴AsyncJava

2022-09-05 10:06:21

MySQL外循環(huán)內(nèi)循環(huán)

2013-08-22 09:26:38

去IOE王堅(jiān)

2011-05-26 14:27:56

java

2016-08-18 14:13:55

JavaScript基本數(shù)據(jù)引用數(shù)據(jù)

2019-09-04 11:02:54

繼承層次組合

2010-10-08 09:02:03

JavaScript基

2019-09-02 15:20:28

Java開發(fā)繼承

2023-04-03 07:03:51

阿里巴巴List元素

2016-09-21 20:28:55

阿里巴巴IOE

2020-08-05 11:30:59

日期格式化代碼Java

2018-12-29 15:41:41

阿里巴巴程序員serialVersi

2020-09-08 16:25:18

Apache BeancopyJava

2020-07-30 12:16:33

阿里巴巴Apache對象

2020-09-22 11:40:53

BigDecimalequalsJava

2025-04-17 08:47:23

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號