之前正常工作的代码再升级jdk8之后出现了异常,提示:
java.lang.ClassCastException: java.math.BigDecimal cannot be cast to [Ljava.lang.Object;
一开始觉得,卧槽,不可能。
怎么BigDecimal 不能转换为Object啊,不科学。
细看才发现是Object数组
BigDecimal 不能强转为 Object[]就说的通了
但是我本地的代码确实没问题,为什么同事的代码就出问题了呢?
出错的一行代码如下
List<Record> find = Db.find(sql, user.get("tdbh"));
其中Db.find()方法形参是(String sql, Object… args)
user.get(String)返回值是 T;
是一个比较常见的数据库工具类。系统里面很多地方都有这样的写法,想不通为什么这里会出错.
既然这样的话,只能考虑是不同jdk版本的问题了。
我们把不同jdk编译后的class反编译看了一下,原来是出了大问题,
jdk8编译后的class文件反编译的结果是
jdk7编译的结果是
从上面可以看到不同版本的jdk对这行代码的编译是不一样的,jdk8把BigDecimal强制转换为Object[],jdk7是new 了一个Obkect[],把BigDecimal作为它的一个初始化值。
到这里就很清楚为什么jdk8会报错了。
这种bug简直蛋疼,我觉得同一开发团队使用相同版本的jdk还是比较靠谱的,同理的还有tomcat等各种各样的开发工具,甚至了IDE。
比较神奇的是,我们把BigDecimal toString之后,编译的话jdk8也会也new Object[]的方式转换它。所以我就把他toString了。