一、当把Object数组,强转的具体的Integer数组时,会报错。

代码如下:

   //数组强转报错演示  
  Object[] numbers = {1,2,3};
Integer[] ints = (Integer[])numbers;

报错:

java.lang.ClassCastException: [Ljava.lang.Object; cannot be cast to [Ljava.lang.Integer;

原因:

  根本原因还是类型的继承关系问题,Integer[]并不是Object[]的子类。虽然,Integer继承自Object,但Integer[]的直接父类是Object。即所有数组类型的直接父类都是Object,可以通过反射来验证。数组类型是写在jvm里得,就像8种基本类型,我们无法在java的标准库中找到这个类。

//数组的直接父类演示
@Test
public void testArrayClass() {
Integer[] i = {1,2,3};
Object[] o = {1,2,3};
System.out.println(o.getClass().getSuperclass().getName());
System.out.println(i.getClass().getSuperclass().getName());
}

输出结果:

java.lang.Object
java.lang.Object

解决方案,可以对数组每个成员分别转化:

   @Test
public void testArrayChange() {
Object[] numbers = {1,2,3};
Integer[] ints = new Integer[numbers.length];
for(int i = 0;i<numbers.length;i++) {
ints[i] = (Integer)numbers[i];
}
}

二、另外:虽然强转会有类型转换异常,但是,java有一个语法特性:

  当A被B继承时,A[]类型的引用可以指向B[]类型的实例.

    即:A[] a = new B[3]成立。

    @Test
public void testArrayClass() {
Integer[] i = {1,2,3};
Object[] o = i;
System.out.println("引用成功!!");
}

控制台:

引用成功!!

这种情况被允许,是java的一个语法特性,这种语法特性的存在是为了方法中参数传递的方便。

在给数据库语句传递参数时,将多个参数传递给sql语句中的每一个占位符,可以使用Object[]类型的参数来接收,然后,在方法中遍历数组元素,根据不同类型,转化成相应的类型数据。

    @Test
public void testTraversalObject() {
Integer[] a = {1,2,3};
String[] b = {"a","b","c"};
traversalArray(a);
traversalArray(b);
} public void traversalArray(Object[] o) {
for(int i = 0;i<o.length;i++) {
if(o[i] instanceof Integer) {
System.out.println("PreparedStatement添加int参数");
}
if(o[i] instanceof String) {
System.out.println("PreparedStatement添加String参数");
}
if(o[i] instanceof java.util.Date) {
System.out.println("PreparedStatement添加String参数");
}
else {
System.out.println("还有其他类型得意添加!");
}
}
}

如果没有这个特性:

  1、在方法中定义Object类型的参数,来接收数组参数,如果在代码内部进行类型转化,则有类型转化异常的风险,因为,Object是顶级父类,传递的参数可以不是个数组

Object obj = 1;
Object[] objs = (Object[]) obj;

  2、使用具体的数据类型数组,String[],Integer[],则会使类型的限制太过固定失去灵活性,每种类型都要新增一个方法来代替。

 @Test
public void testTraversalObject() {
Integer[] a = {1,2,3};
String[] b = {"a","b","c"};
traversalIntegerArray(a);
traversalStringArray(b);
} public void traversalIntegerArray(Integer[] arr) {
for(int i = 0;i<arr.length;i++) {
//给PreparedStatement添加参数
     }
   }
   
  public void traversalStringArray(String[] arr) {
for(int i = 0;i<arr.length;i++) {
//给PreparedStatement添加参数
     }
   }
}

关于Object数组强转成Integer数组的问题:Ljava.lang.Object; cannot be cast to [Ljava.lang.Integer;的更多相关文章

  1. 关于Object[]数组强转成Integer[]类型的数组.

    为什么不能由Object[]数组强转成Integer[]数组. Object[] ins= { new Integer(0), new Integer(1), new Integer(2), new ...

  2. java.lang.ClassCastException: java.lang.Short cannot be cast to java.lang.String(Short类型无法强转成String类型)

    有一行Java代码如下: String code1 = (String)qTable1.getValueAt(i, 0); 这是一个Java的图形界面获取表格中值的代码,其中qTable1.getVa ...

  3. ArrayMap java.lang.ClassCastException: java.lang.String cannot be cast to java.lang.Object[]

    错误堆栈: java.lang.ClassCastException: java.lang.String cannot be cast to java.lang.Object[] at android ...

  4. java.lang.ClassCastException: java.lang.Long cannot be cast to java.lang.Integer

    hibernate查询结果条数集 原写法: Integer count = (Integer )session.createQuery(hql).uniqueResult(); 报错:java.lan ...

  5. java.lang.Long cannot be cast to java.lang.Integer解决办法

    情景: mybatis连接oracle 报错: 测试增的时候,报错 Java.lang.Long cannot be cast to  java.lang.Integer:删改没有报错. 排查过程: ...

  6. PHP二维数组(或任意维数组)转换成一维数组的方法汇总(实用)

    目录 1 array_reduce函数法 2 array_walk_recursive函数法 3 array_map函数法 假设有下面一个二维数组: $user = array( '0' => ...

  7. PHP实现二维数组(或多维数组)转换成一维数组

    1 array_reduce函数法 用array_reduce()函数是较为快捷的方法: $result = array_reduce($user, function ($result, $value ...

  8. js 一维数组,转成嵌套数组

    // 情况一: // 数据源var egs = [ {name_1: 'name_1...'}, {name_2: 'name_4...'}, {name_3: 'name_3...'}, {name ...

  9. Java中 如何把Object类型强转成Map<String, String>类型

    首先你需要保证要转换的Object的实际类型是Map<String, String> 假设Object变量名为obj,强制转换(Map<String, String>)obj ...

随机推荐

  1. 小程序如何获取code

    小程序如何获取code <button open-type="getUserInfo" hover-class='none' bindgetuserinfo="ge ...

  2. LVS DR模式配置

    关于LVS的相关介绍,以下两篇文章均做了具体的介绍: http://www.linuxvirtualserver.org/zh/lvs1.html http://www.cnblogs.com/liw ...

  3. Abp + MongoDb 改造默认的审计日志存储位置

    一.背景 在实际项目的开发当中,使用 Abp Zero 自带的审计日志功能写入效率比较低.其次审计日志数据量中后期十分庞大,不适合与业务数据存放在一起.所以我们可以重新实现 Abp 的 IAuditi ...

  4. mysql 开发进阶篇系列 48 物理备份与恢复(xtrabackup 的增量备份与恢复,以及备份总结)

    一.增量备份概述 xtrabackup  和innobackupex  二个工具都支持增量备份,这意味着能复制自上次备份以来更改的数据.可以在每个完整备份之间执行许多增量备份,因此,您可以设置一个备份 ...

  5. sql server I/O硬盘交互

    一. 概述 sql server作为关系型数据库,需要进行数据存储, 那在运行中就会不断的与硬盘进行读写交互.如果读写不能正确快速的完成,就会出现性能问题以及数据库损坏问题.下面讲讲引起I/O的产生, ...

  6. sql server 性能调优之 资源等待内存瓶颈的三种等待类型

    一.概述 这篇介绍Stolen内存相关的主要三种等待类型以及对应的waittype编号,CMEMTHREAD(0x00B9),SOS_RESERVEDMEMBLOCKLIST(0x007B),RESO ...

  7. 一套能体现 RBAC 的表结构设计

    1.RBAC 概述 2.表结构设计 2.1.用户表 2.2.角色表 2.3.权限表 2.4.用户角色(关系)表 2.5.角色权限(关系)表 3.总结 1.RBAC 概述 RBAC(Role-Based ...

  8. vue-07-自定义指令

    1, 全局指令 在main.js中引入 // 注册一个全局自定义指令 `v-focus` Vue.directive('focus', { // 当被绑定的元素插入到 DOM 中时…… inserte ...

  9. leetcode — merge-intervals

    import java.util.ArrayList; import java.util.Arrays; import java.util.Collections; import java.util. ...

  10. 云数据库POLARDB优势解读之①——10分钟了解

    什么是POLARDB POLARDB 是阿里云自研的下一代关系型分布式数据库,100%兼容MySQL,之前使用MySQL的应用程序不需要修改一行代码,即可使用POLARDB. POLARDB在运行形态 ...