Java中基本类型直接存值于栈,引用类型存堆中对象地址;Integer等包装类有缓存机制(-128~127),自动装箱拆箱易引发NullPointerException,==比较引用而非值,数组和String均为引用类型,类型转换需注意范围与安全性。

Java中基本类型和引用类型的根本区别
基本类型(int、double、boolean等)直接存储值,占用栈内存;引用类型(String、ArrayList、自定义类等)存储的是堆中对象的地址,变量本身在栈上。这个差异直接影响赋值行为和内存管理。
常见误判场景:
- 把
Integer当成基本类型用,结果遇到NullPointerException(比如Integer i = null; int j = i;会抛出异常) - 用
==比较两个String内容,实际比的是引用是否相同,应改用.equals() - 认为
int[]是基本类型数组,其实它仍是引用类型——int[] arr1 = {1}; int[] arr2 = {1}; System.out.println(arr1 == arr2); // false
自动装箱/拆箱的隐式转换规则与陷阱
Java在Integer和int之间自动转换,但仅限于“有明确上下文”的场景,且受缓存机制限制。
关键事实:
立即学习“Java免费学习笔记(深入)”;
EasySitePM Enterprise3.5系统是一款适用于不同类型企业使用的网站管理平于,它具有多语言、繁简从内核转换、SEO搜索优化、图片自定生成、用户自定界面、可视化订单管理系统、可视化邮件设置、模板管理、数据缓存+图片缓存+文件缓存三重提高访问速度、百万级数据快速读取测试、基于PHP+MYSQL系统开发,功能包括:产品管理、文章管理、订单处理、单页信息、会员管理、留言管理、论坛、模板管
-
Integer在-128到127范围内复用缓存对象,所以Integer a = 100; Integer b = 100; a == b为true;但Integer c = 200; Integer d = 200; c == d为false - 任何涉及算术运算的表达式都会触发拆箱,如
Integer x = null; int y = x + 1;运行时报NullPointerException - 泛型容器(如
ArrayList)强制要求包装类型,不能写ArrayList
显式类型转换(强制类型转换)的安全边界
只对数值类型间转换有效,且必须满足范围兼容性。越界转换不报错但结果不可预期。
int i = 200; byte b = (byte) i; // 不报错,但b = -56(200 % 256 = 200,超出byte范围后截断) long l = 100L; int j = (int) l; // 安全,因为l在int范围内 float f = 1.23f; int k = (int) f; // 截断小数部分 → k = 1,不是四舍五入
注意:
- 不能对
String直接强转为int,必须用Integer.parseInt() -
Object o = "hello"; String s = (String) o;合法;但若o = new Object()再强转就会ClassCastException - 接口类型转换需确保运行时对象实际实现了该接口
字符串与其他类型的相互转换惯用法
字符串是引用类型,但和基本类型之间的转换最常被误用。核心原则:没有隐式转换,全是方法调用。
- 基本类型 →
String:优先用String.valueOf(x)(安全,可处理null),避免x + ""(性能差、语义模糊) -
String→ 基本类型:用Integer.parseInt(s)等,失败抛NumberFormatException;若可能为空或格式不稳,先校验再转,或用Optional.ofNullable(s).map(Integer::parseInt).orElse(-1) -
String↔char[]:用s.toCharArray()和new String(chars),注意后者会拷贝数组,修改原数组不影响字符串
类型转换不是语法糖,是运行时行为。真正容易出问题的,往往不是不会写,而是没意识到某次调用背后发生了拆箱、缓存失效或隐式创建新对象。









