jdk版本导致的类型转换异常

之前正常工作的代码再升级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了。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值