java stringtoarray_java中toArray()的用法
一直不太熟悉toarray()的用法 現整理如下
一.Incident
public?static?void?main(String[]?args)?{
List?list?=?new?ArrayList();
list.add("1");
list.add("2");
String[]?tt?=?(String[])?list.toArray(new?String[0]);
}
這段代碼是沒問題的,但我們看到String[] tt =(String[]) list.toArray(new String[0]) 中的參數很奇怪,然而去掉這個參數new String[0]卻在運行時報錯.
二. Root Cause Analysis
經研究發現toArray有兩個方法:
public?Object[]?toArray()?{
Object[]?result?=?new?Object[size];
System.arraycopy(elementData,?0,?result,?0,?size);
return?result;
}
不帶參數的toArray方法,是構造的一個Object數組,然后進行數據拷貝,此時進行轉型就會產生ClassCastException,這也就是上述問題的root cause了。
public?Object[]?toArray(Object?a[])?{
if?(a.length?
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方法,則是根據參數數組的類型,構造了一個對應類型的,長度跟ArrayList的size一致的空數組,雖然方法本身還是以 Object數組的形式返回結果,不過由于構造數組使用的ComponentType跟需要轉型的ComponentType一致,就不會產生轉型異常。
三. Solutions
因此在使用toArray的時候可以參考以下三種方式
1.?Long[]?l?=?new?Long[];
list.toArray(l);
2.?Long[]?l?=?(Long[])?list.toArray(new?Long[0]);
3.?Long[]?a?=?new?Long[];
Long[]?l?=?(Long[])?list.toArray(a);
四.Further Consideration
該容器中的元素已經用泛型限制了,那里面的元素就應該被當作泛型類型的來看了,然而在目前的java中卻不是的,當直接String[] tt =(String[]) list.toArray()時,運行報錯。回想一下,應該是java中的強制類型轉換只是針對單個對象的,想要偷懶,將整個數組轉換成另外一種類型的數組是不行的,這和數組初始化時需要一個個來也是類似的。
總結
以上是生活随笔為你收集整理的java stringtoarray_java中toArray()的用法的全部內容,希望文章能夠幫你解決所遇到的問題。
                            
                        - 上一篇: java byte缓存_Java 之 字
 - 下一篇: java绘图板_Java中的画图板简单功