这是一个开发规范的问题。在阿里巴巴 Java 的开发手册中有这么一段:
为什么要加一个这样的强制呢?
回答
大明哥认为有如下几个原因。
原因一:空值的表达能力
包装类型默认 null,而基本数据类型不能。这使得包装类型可以更加准确地表达出属性缺少值的意义。而这个能力在于数据库交互及对象之间的数据传递时尤其有用。
比如,我们有一个考试系统,课程 Course 类里面有一个属性completed
表示用户是否完成了课程:
public class Course {
private Boolean completed; // 使用包装类型Boolean
// 其他属性和方法
}
如果我们使用包装类,那么默认为空,可以表达这门课程的用户状态是未知的,这可能意味着学生尚未开始课程或系统尚未更新他们的进度。而如果使用基本类型,则默认为 false,则表示用户尚未完成课程,容易产生歧义。
原因二:避免默认值带来的歧义
基本数据类型有默认值,如int
的默认值为0
。在某些场景下,这可能会引入歧义,比如我们无法区分0
是刻意设置的值还是一个未被初始化的字段。而使用包装类型,则可以通过null
值明确表示字段未被设置。
比如,我们用一个订单类 Order,他有一个折扣金额,这个时候我们就只能使用 Integer
而不是 int
。在某些情况下,订单是可能没有任何折扣的。这个时候,discount
属性应该被设置为null
,明确表示“没有折扣”或“折扣信息未设置”,而不是0
。0
作为一个有效的折扣金额(即没有折扣),与“未设置折扣”是两种不同的业务场景。可能有小伙伴说,我加一个判断,0
表示没折扣,但是在有些情况下是会存在 0 折扣的啊,这个时候你如何区分呢?
原因三:泛型和集合的兼容性
Java的集合框架和泛型只支持引用类型,不支持基本数据类型。使用包装类型作为对象属性,可以无缝地将这些属性添加到集合中,或者在使用泛型时避免自动装箱和拆箱的性能开销。