valueOf 返回包装类对象,parseXXX 返回基本类型;二者均不接受 null,均抛出 NumberFormatException;valueOf 对 -128~127 整数有缓存优化,parseXXX 无缓存;需对象时用 valueOf,只需原始值时用 parseXXX。

Java 中 valueOf 和 parseXXX(如 parseInt、parseBoolean)都用于字符串转基本类型或其包装类,但返回类型、空值处理、缓存机制和使用场景有本质区别。
返回类型不同:包装类 vs 基本类型
valueOf 方法(如 Integer.valueOf(String))返回的是对应包装类对象(Integer),而 parseXXX(如 Integer.parseInt(String))返回的是基本类型(int)。
这意味着:
- 调用
valueOf后可直接用于泛型集合(如List<integer></integer>)、反射或需要对象的 API; - 调用
parseXXX得到的是原始值,若需包装类,会触发自动装箱(可能带来额外开销或空指针风险); - 例如:
Integer i1 = Integer.valueOf("123");✅;int i2 = Integer.parseInt("123");✅;但Integer i3 = Integer.parseInt("123");会先得到int再装箱为Integer。
对 null 的处理行为不同
parseXXX 方法遇到 null 字符串时,一律抛出 NumberFormatException;valueOf 行为一致,也抛出相同异常——二者都不接受 null。
立即学习“Java免费学习笔记(深入)”;
注意:这不是“安全”方法。若需容错,必须手动判空:
- ❌
Integer.parseInt(null)→NumberFormatException - ❌
Integer.valueOf(null)→NumberFormatException - ✅ 正确做法:
str != null ? Integer.valueOf(str) : null
valueOf 具有缓存优化,parseXXX 没有
Integer.valueOf(String) 内部调用 Integer.valueOf(int),而后者对 [-128, 127] 范围内的整数做了缓存(JLS 规定),重复调用会返回同一对象引用;parseInt 只做数值解析,不涉及对象创建与缓存。
效果示例:
Integer a = Integer.valueOf("100");Integer b = Integer.valueOf("100");System.out.println(a == b); // true(命中缓存)- 而
Integer c = Integer.parseInt("100"); // 自动装箱 → new Integer(100) 或缓存?取决于编译器和值,但语义上不保证复用对象。
这个特性让 valueOf 在频繁构造小整数包装类时更高效且利于 == 判等(仅限缓存范围)。
适用场景建议
选哪个,看你要什么:
- 需要 包装类对象(如存入集合、作为方法参数、配合 Optional)→ 优先用
valueOf; - 只需要 计算或比较原始值,且后续不常转回对象 →
parseXXX更直接,避免无谓装箱; - 性能敏感且值集中在 -128~127 →
valueOf有缓存优势; - 统一风格或团队规范明确时,建议以
valueOf为主(它更面向对象,且 JDK 9+ 中parseXXX实际被valueOf内部调用)。
不复杂但容易忽略:它们不是互换的工具,而是分工明确的转换入口——一个造对象,一个产原始值。










