在看代碼的過程中,看到了這種用法
fnList.toArray(new String[0])
很困惑,不知道這個是幹什麼的,就上網搜以下。
http://rogerfederer.iteye.com/blog/788795 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; }
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()]);
http://blog.csdn.net/jrq/article/details/517428