经验笔记 - java中常见的异常 java.lang.ClassCastException

java.lang.ClassCastException

java.lang.ClassCastException的java类型转换异常

这个错误也很常见,通常在程序中出现强制类型转换时出现这个错误,如下面这段代码所示:

    public static Map m = new HashMap() {
		{
			put("a", "2");
		}
	};
 
	public static void main(String[] args) {
		Integer isInt = (Integer) m.get("a");
		System.out.println(isInt);
	}

当强制将本来不是Integer类型的字符串转成Integer类型时会报类似如下错误:

java.lang.ClassCastException: org.apache.hadoop.fs.s3a.commit.staging.DirectoryStagingCommitter cannot be cast to org.apache.hadoop.mapreduce.lib.output.FileOutputCommitter

在Hadoop系列编码中,尤其在一些源码和配置的情况下,会报出java.lang.ClassCastException异常

 

JVM在做类型转换时会按照如下规则进行检查:

  •     对于普通对象,对象必须是目标类的实例或目标类的子类的实例。如果目标类是接口,那么会把他当作实现了该接口的一个子类。
  •     对于数组类型,目标类必须是数组类型或java.lang.Object、java.lang.Cloneable、java.io.Serializable。

如果不满足上面的规则,JVM会报这个错误了。要避免这个错误有两种方式:

  •     在容量类型中显式的指明这个容器所包含的对象类型,如在上面的Map中可以写为Map m = new HashMap(),这样上面的代码在编译阶段就会检查通过。
  •     先通过instanceof检查是不是目标类型,然后再进行强制类型转换。

 

参考

https://blog.csdn.net/en_joker/article/details/81449932

你可能感兴趣的:(经验)