您的位置:首页 > 编程语言 > Java开发

JDk---集合转数组的toArray()和toArray(T[] a)方法

2014-12-17 11:23 375 查看
代码是jdk ArrayList中的源码 

Java代码  


   

public <T> T[] toArray(T[] a) {   

        if (a.length < size)   

            a = (T[])java.lang.reflect.Array.   

                newInstance(a.getClass().getComponentType(), size);   

            System.arraycopy(elementData, 0, a, 0, size);   

        if (a.length > size)   

            a[size] = null;   

        return a;   

    }   

  

  

  

 public Object[] toArray()  

    {  

        Object aobj[] = new Object[size];  

        System.arraycopy(((Object) (elementData)), 0, ((Object) (aobj)), 0, size);  

        return aobj;  

    }  

  

    public Object[] toArray(Object aobj[])  

    {  

        if(aobj.length < size)  

            aobj = (Object[])(Object[])Array.newInstance(((Object) (aobj)).getClass().getComponentType(), size);  

        System.arraycopy(((Object) (elementData)), 0, ((Object) (aobj)), 0, size);  

        if(aobj.length > size)  

            aobj[size] = null;  

        return aobj;  

    }  

1.该方法用了泛型,并且是用在方法的创建中(<T> 相当于定义泛型,T[]是在使用泛型T) 
泛型是Java SE 1.5的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数。这种参数类型可以用在类、接口和方法的创建中,分别称为泛型类、泛型接口、泛型方法 
2.该方法返回集合中所有元素的数组;返回数组的运行时类型与指定数组的运行时类型相同。 

3.与 public Object[] toArray() 的比较 
public Object[] toArray() { 
Object[] result = new Object[size]; 
System.arraycopy(elementData, 0, result, 0, size); 
return result; 
    } 

从源码中可以看出它仅能返回 Object[]类型的,相当于toArray(new Object[0]) 注意:数组不能强制转换 

不带参数的toArray方法,是构造的一个Object数组,然后进行数据拷贝,此时进行转型就会产生ClassCastException 

String[] tt =(String[]) list.toArray(new String[0]); 
这段代码是没问题的,但我们看到String[] tt =(String[]) list.toArray(new String[0]) 中的参数很奇怪,然而去掉这个参数new String[0]却在运行时报错。。。 

该容器中的元素已经用泛型限制了,那里面的元素就应该被当作泛型类型的来看了,然而在目前的java中却不是的,当直接String[] tt =(String[]) list.toArray()时,运行报错。回想一下,应该是java中的强制类型转换只是针对单个对象的,想要偷懒将整个数组转换成另外一种类型的数组是不行的,,这和数组初始化时需要一个个来也是类似的。 

带参数的toArray方法,则是根据参数数组的类型,构造了一个对应类型的,长度跟ArrayList的size一致的空数组,虽然方法本身还是以
Object数组的形式返回结果,不过由于构造数组使用的ComponentType跟需要转型的ComponentType一致,就不会产生转型异常。 

解决方案. Solutions 

  因此在使用toArray的时候可以参考以下三种方式 

  1. Long[] l = new Long[<total size>]; 

     list.toArray(l); 

  2. Long[] l = (Long[]) list.toArray(new Long[0]); 

  3. Long[] a = new Long[<total size>]; 

      Long[] l = (Long[]) list.toArray(a); 

1).参数指定空数组,节省空间 
String[] y = x.toArray(new String[0]); 
2).指定大数组参数浪费时间,采用反射机制 
String[] y = x.toArray(new String[100]);  //假设数组size大于100 
3).姑且认为最好的 
String[] y = x.toArray(new String[x.size()]); 

以下代码会出现ClassCastException 
List list = new ArrayList();   
list.add(new Long(1)); 
list.add(new Long(2));   
list.add(new Long(3)); 
list.add(new Long(4));   
Long[] l = (Long[])list.toArray();//这个语句会出现ClassCastException 

处理方式如下面代码: 
Long [] l = (Long []) list.toArray(new Long[list.size()]);   
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java.util.list java