为什么阿里巴巴要求POJO中不能使用基本数据类型?

这里强制要求使用包装类型,原因是什么呢?

成都创新互联专注于资源企业网站建设,响应式网站设计,商城网站定制开发。资源网站建设公司,为资源等地区提供建站服务。全流程按需制作网站,专业设计,全程项目跟踪,成都创新互联专业和态度为您提供的服务

我们来看一段简单的代码:

     /**

* @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();

}

}

以上代码输出结果为:

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

可以看到,当我们没有设置Model对象的字段的值的时候,Boolean类型的变量会设置默认值为null,而boolean类型的变量会设置默认值为false。

即Boolean对象的默认值是null,boolean基本数据类型的默认值是false。

也就是说,包装类型的默认值都是null,而基本数据类型的默认值是一个固定值,如boolean是false,byte、short、int、long是0,float是0.0f等;

我们再举一个扣费的例子,我们做一个扣费系统,扣费时需要从外部的定价系统中通过 RPC 请求读取一个费率的值,我们预期该接口的返回值中会包含一个浮点型的费率字段。当我们取到这个值得时候就使用公式:金额*费率=费用 进行计算,计算结果进行划扣。

如果由于计费系统异常,他可能会返回个默认值,如果这个字段是Double类型的话,该默认值为null,如果该字段是double类型的话,该默认值为0.0。

如果扣费系统对于该费率返回值没做特殊处理的话,拿到null值进行计算会直接报错,阻断程序。拿到0.0可能就直接进行计算,得出接口为0后进行扣费了。这种异常情况就无法被感知。

有人说,那我可以对0.0做特殊判断,如果是0一样可以阻断报错啊。但是,这时候就会产生一个问题,如果允许费率是0的场景又怎么处理呢?

所以,使用基本数据类型只会让方案越来越复杂,坑越来越多。

这种使用包装类型定义变量的方式,通过异常来阻断程序,进而可以被识别到这种线上问题。如果使用基本数据类型的话,系统可能不会报错,进而认为无异常。

当然,以上的选择是针对一些电商、支付、金融等场景,可以牺牲暂时的可用性的场景,如果是对于某些软件系统,可以容忍数据不准,但是不能系统不可用的情况要另当别论。

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

新闻名称:为什么阿里巴巴要求POJO中不能使用基本数据类型?
文章源于:http://www.shufengxianlan.com/qtweb/news3/308353.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联