在Java中,Integer.parseInt和Integer.valueOf有什么区别

🦊一句话总结

Integer.parseInt(s) 直接返回 int 原始类型,而 Integer.valueOf(s) 返回 Integer 对象(会利用缓存优化性能,-128~127 范围内对象复用)。

intparseInt,要 Integer 对象用 valueOf,高频操作用 parseInt 避免装箱开销。

🎯总结

  • Integer.parseInt(s) :直接返回 int,无缓存,适合需要原始类型的场景。

  • Integer.valueOf(s) :返回 Integer优先使用缓存,适合需要对象且值在 -128 ~ 127 的场景。

  • 本质关系valueOfparseInt 的"增强版",内部先调用 parseInt,再自动装箱。

方法 返回类型 是否使用缓存 底层实现 适用场景
Integer.parseInt(s) int ❌ 不适用 直接计算字符串数值 需要原始类型 int 的场景
Integer.valueOf(s) Integer ✅ 使用缓存 内部调用 parseInt(s) + 自动装箱 需要 Integer 对象的场景

代码示例

(1)Integer.parseInt(s)

java 复制代码
String s = "127";
int a = Integer.parseInt(s);        // 返回 int(原始类型)
Integer b = Integer.parseInt(s);    // 自动装箱(等价于 Integer.valueOf(127))

System.out.println(a); // 127(int)
System.out.println(b); // 127(Integer,但会使用缓存)
  • 特点
    • 返回 int,无缓存概念。
    • 若需 Integer,需额外装箱(JVM 可能优化为 valueOf)。

(2)Integer.valueOf(s)

java 复制代码
String s = "127";
Integer c = Integer.valueOf(s);     // 返回 Integer(可能来自缓存)
Integer d = Integer.valueOf("200"); // 返回新 Integer 对象(超出缓存范围)

System.out.println(c == Integer.valueOf(127)); // true(同一缓存对象)
System.out.println(d == Integer.valueOf(200)); // false(不同对象)
  • 特点
    • 返回 Integer优先使用缓存(-128 ~ 127)
    • 内部实现:先 parseInt(s),再 Integer.valueOf(int)

底层实现源码

(1)Integer.parseInt(s)

java 复制代码
public static int parseInt(String s) throws NumberFormatException {
    return parseInt(s, 10); // 默认十进制
}

public static int parseInt(String s, int radix) {
    // 逐字符解析,计算数值...
    // 无缓存,直接返回 int
}

(2)Integer.valueOf(s)

java 复制代码
public static Integer valueOf(String s) throws NumberFormatException {
    return Integer.valueOf(parseInt(s)); // 先解析为 int,再装箱(可能缓存)
}

public static Integer valueOf(int i) {
    if (i >= IntegerCache.low && i <= IntegerCache.high) {
        return IntegerCache.cache[i + (-IntegerCache.low)]; // 缓存
    }
    return new Integer(i); // 新建对象
}

性能对比

场景 推荐方法 原因
需要 int 原始类型 Integer.parseInt(s) 避免自动装箱开销(直接返回 int
需要 Integer 对象 Integer.valueOf(s) 利用缓存(-128 ~ 127),减少对象创建
高频调用(如循环内) Integer.parseInt(s) 避免装箱/拆箱(若业务允许用 int
处理用户输入/配置文件 Integer.valueOf(s) 更安全(返回 Integer 可判 nullint 无法判 null

🐼特殊场景

1、字符串含非数字字符

java 复制代码
String s = "123abc";
Integer.parseInt(s); // 抛出 NumberFormatException
Integer.valueOf(s);  // 同样抛出 NumberFormatException
  • 两者行为一致,均严格校验字符串。

2、空字符串或 null

java 复制代码
Integer.parseInt("");   // 抛出 NumberFormatException
Integer.valueOf(null);  // 抛出 NullPointerException

3、十六进制/八进制

java 复制代码
int hex = Integer.parseInt("FF", 16); // 255
int octal = Integer.parseInt("17", 8); // 15
// valueOf 不支持进制参数,需用 parseInt + valueOf
Integer i = Integer.valueOf(Integer.parseInt("FF", 16)); // 255
相关推荐
初次攀爬者2 分钟前
Kafka + ZooKeeper架构基础介绍
后端·zookeeper·kafka
SuperEugene4 分钟前
Vue状态管理扫盲篇:如何设计一个合理的全局状态树 | 用户、权限、字典、布局配置
前端·vue.js·面试
LucianaiB4 分钟前
Openclaw 安装使用保姆级教程(最新版)
后端
华仔啊19 分钟前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang27 分钟前
用六边形架构与整洁架构对比是伪命题?
java·架构
哈密瓜的眉毛美30 分钟前
零基础学Java|第五篇:进制转换与位运算、原码反码补码
后端
开心就好20251 小时前
免 Xcode 的 iOS 开发新选择?聊聊一款更轻量的 iOS 开发 IDE kxapp 快蝎
后端·ios
Java编程爱好者1 小时前
为什么国内大厂纷纷”弃坑”MySQL,转投PostgreSQL阵营?
后端
神奇小汤圆2 小时前
金三银四Java面试题及答案汇总(2026持续更新)
后端
Ray Liang2 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计