查看原文
其他

为什么阿里巴巴禁止开发人员 boolean 类型变量使用 isXXX 来命名?

Java精选 2022-08-09

>>号外:关注“Java精选”公众号,菜单栏->聚合->干货分享,回复关键词领取视频资料、开源项目。

背景
平时工作中大家经常使用到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来命名
1)对于非boolean类型的参数,getter和setter方法命名的规范是以get和set开头
2)对于boolean类型的参数,setter方法是以set开头,但是getter方法命名的规范是以is开头
3)包装类自动生成的getter和setter方法的名称都是getXXX()和setXXX()
a. 其实javaBeans规范中对这些均有相应的规定,基本数据类型的属性,其getter和setter方法是getXXX()和setXXX,但是对于基本数据中布尔类型的数据,又有一套规定,其getter和setter方法是isXXX()和setXXX。但是包装类型都是以get开头
b. 这种方式在某些时候是可以正常运行的,但是在一些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中使用包装数据类型,局部变量使用基本数据类型。

作者:Apple_Web

blog.csdn.net/belongtocode/article/details/100635246

往期精选  点击标题可跳转

为什么 MyBatis 在国内非常流行,而国外 Java 工程师却不愿意使用?

IntelliJ IDEA 使用 spring Initializr 快速搭建 spring boot 项目遇到的坑

面试官问:为什么 MySQL 中的 utf8 并不是真正的 UTF-8 编码?

为什么程序员都说 SELECT * 效率低,那究竟是什么原因造成的?

厉害了,淘宝千万级并发,14次分布式架构演进

Spring Cloud 中 Zuul 网关到底有何牛逼之处?竟然这么多人在用!

一次神奇的 sql 查询经历,group by 慢查询优化记录

腾讯 Tendis 正式开源,兼容 Redis 协议企业级分布式高性能 KV 存储数据库

中国铁路 12306 网站的高并发架构带来的思考?研究分析后,果然超牛逼…

IDEA JetBrains 推出 Mono 编程字体真牛逼,更适合程序开发人员!

为什么阿里规范中要求代码禁用 static 修饰 SimpleDateFormat?

点个赞,就知道你“在看”!

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存