转载自http://www.roboticfan.com/blog/user_2005/104/archives/2007/20071127213533.shtml
List list = new ArrayList();
list.add(new Person());
list.add(new Person());
list.add(new Person());
Person[] person = (Person[]) list.toArray();
运行程序会抛出异常:java.lang.ClassCastException
但运行如下代码:
List list = new ArrayList();
list.add(new Person());
list.add(new Person());
list.add(new Person());
Person[] person = (Person[]) list.toArray(new Person[0]);
程序正确执行,
原因,先看ArrayList的两个toArray()方法的源代码:
public Object[] toArray() {
Object[] result = new Object[size];
System.arraycopy(elementData, 0, result, 0, size);
return result;
}
public Object[] toArray(Object a[]) {
if (a.length < size)
a = (Object[])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;
}
可以看出,不带参数的toArray方法,是构造的一个Object数组,然后进行数据拷贝,此时进行转型就会产生ClassCastException而带参数的toArray方法,则是根据参数数组的类型,构造了一个对应类型的,长度跟ArrayList的size一致的空数组,虽然方法本身还是以Object数组的形式返回结果,不过由于构造数组使用的ComponentType跟需要转型的ComponentType一致,就不会产生转型异常。
那么,对于不带参数的toArray方法,它有什么特殊意义呢?还是用代码说话:
ArrayList list = new ArrayList();
list.add(new Person());
list.add(new Person());
list.add(new Person());
//这里不需要转型,也不能使用转型
Object[] ss = list.toArray();
//这里可以进行转型,取出原ArrayList里面存放的对象
for (int i = 0; i < ss.length; i++)
{Person person= (Person) ss[i];
System.out.println(person);
}
就是说,如果用toArray,需要自己“手工”“逐个”进行类型转换。
[@more@]
List list = new ArrayList();
list.add(new Person());
list.add(new Person());
list.add(new Person());
Person[] person = (Person[]) list.toArray();
运行程序会抛出异常:java.lang.ClassCastException
但运行如下代码:
List list = new ArrayList();
list.add(new Person());
list.add(new Person());
list.add(new Person());
Person[] person = (Person[]) list.toArray(new Person[0]);
程序正确执行,
原因,先看ArrayList的两个toArray()方法的源代码:
public Object[] toArray() {
Object[] result = new Object[size];
System.arraycopy(elementData, 0, result, 0, size);
return result;
}
public Object[] toArray(Object a[]) {
if (a.length < size)
a = (Object[])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;
}
可以看出,不带参数的toArray方法,是构造的一个Object数组,然后进行数据拷贝,此时进行转型就会产生ClassCastException而带参数的toArray方法,则是根据参数数组的类型,构造了一个对应类型的,长度跟ArrayList的size一致的空数组,虽然方法本身还是以Object数组的形式返回结果,不过由于构造数组使用的ComponentType跟需要转型的ComponentType一致,就不会产生转型异常。
那么,对于不带参数的toArray方法,它有什么特殊意义呢?还是用代码说话:
ArrayList list = new ArrayList();
list.add(new Person());
list.add(new Person());
list.add(new Person());
//这里不需要转型,也不能使用转型
Object[] ss = list.toArray();
//这里可以进行转型,取出原ArrayList里面存放的对象
for (int i = 0; i < ss.length; i++)
{Person person= (Person) ss[i];
System.out.println(person);
}
就是说,如果用toArray,需要自己“手工”“逐个”进行类型转换。
[@more@]
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/74133/viewspace-1046964/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/74133/viewspace-1046964/