Java强制类型转换需谨慎:基本类型转换可能截断或丢失精度,引用类型向下转型须用instanceof校验以防ClassCastException,泛型因类型擦除无法安全转换参数化类型。

Java 中的强制类型转换(Casting)用于将一个类型的值显式转为另一个类型,但并非所有转换都安全——它既可能成功,也可能在运行时抛出异常或导致数据丢失。
基本语法:括号包裹目标类型
强制类型转换的写法是在表达式前加上用圆括号括起的目标类型:
- 基本类型间转换:如 int i = (int) 3.14; —— 将 double 截断为 int,结果为 3
- 引用类型间转换:如 Object obj = new String("hello"); String s = (String) obj; —— 向下转型(downcast),前提是 obj 实际指向 String 对象
- 不能跨无关类转换:比如 (String) new Date() 编译不通过,因 String 和 Date 无继承关系
运行时风险:ClassCastException
引用类型强制转换失败时,JVM 在运行时抛出 ClassCastException。常见于向下转型未校验实际类型:
- 错误示例:Object obj = new Integer(42); String s = (String) obj; —— 运行时报错
- 安全做法:先用 instanceof 判断,再转换:if (obj instanceof String) { String s = (String) obj; }
- 注意:instanceof 对 null 返回 false,因此转换前若对象可能为 null,需单独判断,避免空指针与类型异常混杂
隐式截断与精度丢失:基本类型转换的静默陷阱
基本类型强制转换不会报错,但可能造成不可逆的数据损失,且编译器不警告:
立即学习“Java免费学习笔记(深入)”;
- byte b = (byte) 257; → 实际值为 1(257 % 256,高位被丢弃)
- float f = (float) 10.1234567890123456789; → 精度下降,尾数被舍入
- 从 long 转 int、double 转 float 等“大→小”转换均存在溢出或舍入风险,应结合业务逻辑判断是否需要校验范围(如使用 Math.toIntExact() 捕获溢出)
泛型与类型擦除带来的转换限制
由于 Java 泛型在运行时被擦除,无法对参数化类型做强制转换:
- 以下代码编译失败:List
list = (List ) new ArrayList(); - 只能转为原始类型:List raw = (List) new ArrayList();,但会触发 unchecked 警告
- 尝试转换泛型数组(如 (String[]) obj)是允许的,但仅当 obj 实际是 String[] 或其子类数组;否则仍抛 ClassCastException









