[英]Generic Casting on primitive value causing ClassCastException
我在下面有一个方法根据给定的类型对 String 进行强制转换,假设给定的 String 必须是正确的。
private static <T> T parsePrimitive(final Class<T> primitiveType, final String primitiveValue) {
if (primitiveType.equals(int.class) || primitiveType.equals(Integer.class)) {
return primitiveType.cast(Integer.parseInt(primitiveValue));
}
/*
...
for the rest of the primitive type
...
*/
}
但是,当我调用parsePrimitive(int.class, "10");
时 ,
primitiveType.cast(Integer.parseInt(primitiveValue));
这会导致ClassCastException
,对此有什么想法吗?
ps 事实上,当我使用 Object 作为返回类型,并且在返回之前没有强制转换时,它在方法之外工作正常,但我认为这不够通用。
在此先感谢您的帮助。
您正在混淆自动装箱和铸造。 java 编译器将生成字节码以将您的基元装箱和拆箱到对象,反之亦然,但这同样不适用于类型。
在您的特定情况下, int.class 和 Integer.class 不能相互分配。
Class<?> intClazz = int.class;
Class<?> integerClazz = Integer.class;
System.out.println(intClazz);
System.out.println(integerClazz);
System.out.println(integerClazz.isAssignableFrom(intClazz));
Output:
int
class java.lang.Integer
false
由于您必须在逻辑中进行大量专门检查,我不确定是否值得尝试提出一种将 String 解析为原始值的通用方法。
int.class
是 VM 内部 class 与Integer.class
。 这是一小段代码,用于显示 int.class 和 Integer.class 之间的差异。
import java.lang.reflect.Modifier;
import java.util.Arrays;
public class Main {
public static void main(String[] args) {
dump(int.class);
System.out.println("---");
dump(Integer.class);
}
private static void dump(Class<?> c) {
System.out.printf(
"Name: %s%n" +
"Superclass: %s%n" +
"Interfaces: %s%n" +
"Modifiers: %s%n",
c.getName(),
c.getSuperclass() == null ? "null" : c.getSuperclass().getName(),
Arrays.asList(c.getInterfaces()),
Modifier.toString(c.getModifiers()));
}
}
输出:
Name: int
Superclass: null
Interfaces: []
Modifiers: public abstract final
---
Name: java.lang.Integer
Superclass: java.lang.Number
Interfaces: [interface java.lang.Comparable]
Modifiers: public final
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.