这是一个开发规范的问题。在阿里巴巴 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的集合框架和泛型只支持引用类型,不支持基本数据类型。使用包装类型作为对象属性,可以无缝地将这些属性添加到集合中,或者在使用泛型时避免自动装箱和拆箱的性能开销。
Java 面试宝典是大明哥全力打造的 Java 精品面试题,它是一份靠谱、强大、详细、经典的 Java 后端面试宝典。它不仅仅只是一道道面试题,而是一套完整的 Java 知识体系,一套你 Java 知识点的扫盲贴。
它的内容包括:
- 大厂真题:Java 面试宝典里面的题目都是最近几年的高频的大厂面试真题。
- 原创内容:Java 面试宝典内容全部都是大明哥原创,内容全面且通俗易懂,回答部分可以直接作为面试回答内容。
- 持续更新:一次购买,永久有效。大明哥会持续更新 3+ 年,累计更新 1000+,宝典会不断迭代更新,保证最新、最全面。
- 覆盖全面:本宝典累计更新 1000+,从 Java 入门到 Java 架构的高频面试题,实现 360° 全覆盖。
- 不止面试:内容包含面试题解析、内容详解、知识扩展,它不仅仅只是一份面试题,更是一套完整的 Java 知识体系。
- 宝典详情:https://www.yuque.com/chenssy/sike-java/xvlo920axlp7sf4k
- 宝典总览:https://www.yuque.com/chenssy/sike-java/yogsehzntzgp4ly1
- 宝典进展:https://www.yuque.com/chenssy/sike-java/en9ned7loo47z5aw
目前 Java 面试宝典累计更新 400+ 道,总字数 42w+。大明哥还在持续更新中,下图是大明哥在 2024-12 月份的更新情况:
想了解详情的小伙伴,扫描下面二维码加大明哥微信【daming091】咨询
同时,大明哥也整理一套目前市面最常见的热点面试题。微信搜[大明哥聊 Java]或扫描下方二维码关注大明哥的原创公众号[大明哥聊 Java] ,回复【面试题】 即可免费领取。