我有下面的代碼,它合併兩個數組,並且應該處理除了原語之外的任何類型。當代碼運行Java從另一個數組的通用運行時類型創建數組
@SuppressWarnings("unchecked")
public static synchronized <E> E[] aryMergeNoDup(E[]... arys){
HashSet<E> hs = new HashSet<E>();
for(E[] ary : arys) {
if(ary == null) continue;
for(E item : ary) {
if(item != null) hs.add(item);
}
}
hs.remove(null);
return hs.toArray((E[]) Array.newInstance(
arys.getClass().getComponentType(),hs.size()));
}
然而,它產生此異常:
java.lang.ArrayStoreException: java.lang.String
at java.util.AbstractCollection.toArray(AbstractCollection.java:188)
at util.Utils.aryMergeNoDup(Utils.java:197)
運行時類型的變量arys
的是字符串[];但是,當我用String.class
替換arys.getClass().getComponentType()
時,代碼運行良好。
但是,該方法只能用於字符串,因爲這是pf。我看不出有什麼問題,因爲他們都應該參考java.lang.String
。
拋出異常在AbstractCollection.java:188的行是:
r[i] = (T)it.next();
public <T> T[] toArray(T[] a) {
// Estimate size of array; be prepared to see more or fewer elements
int size = size();
T[] r = a.length >= size ? a :
(T[])java.lang.reflect.Array
.newInstance(a.getClass().getComponentType(), size);
Iterator<E> it = iterator();
for (int i = 0; i < r.length; i++) {
if (! it.hasNext()) { // fewer elements than expected
if (a != r)
return Arrays.copyOf(r, i);
r[i] = null; // null-terminate
return r;
}
r[i] = (T)it.next();
}
return it.hasNext() ? finishToArray(r, it) : r;
}
arys.getClass()。getComponentType()。getComponentType()是一種享受! – user1467885 2013-02-13 18:53:04