したがって、通常ArrayList.toArray()
はObject[]
の型を返しますが、それがオブジェクトArraylist
のCustom
であると仮定した場合、Custom[]
ではなくObject[]
の型を返すようにtoArray()
を作成するにはどうすればよいですか?
このような:
List<String> list = new ArrayList<String>();
String[] a = list.toArray(new String[0]);
Java6より前は、次の記述をお勧めしました。
String[] a = list.toArray(new String[list.size()]);
とにかく、内部実装は適切なサイズの配列を再割り当てするので、事前に実行したほうがよいからです。 Java6では空の配列が優先されるため、 。toArray(new MyClass [0])または.toArray(new MyClass [myList.size()])? を参照してください。
リストが正しく入力されていない場合は、toArrayを呼び出す前にキャストを行う必要があります。このような:
List l = new ArrayList<String>();
String[] a = ((List<String>)l).toArray(new String[l.size()]);
本当にObject[]
を返す必要はありません。例えば:-
List<Custom> list = new ArrayList<Custom>();
list.add(new Custom(1));
list.add(new Custom(2));
Custom[] customs = new Custom[list.size()];
list.toArray(customs);
for (Custom custom : customs) {
System.out.println(custom);
}
これが私のCustom
クラスです:-
public class Custom {
private int i;
public Custom(int i) {
this.i = i;
}
@Override
public String toString() {
return String.valueOf(i);
}
}
arrayList.toArray(new Custom[0]);
@SuppressWarnings("unchecked")
public static <E> E[] arrayListToArray(ArrayList<E> list)
{
int s;
if(list == null || (s = list.size())<1)
return null;
E[] temp;
E typeHelper = list.get(0);
try
{
Object o = Array.newInstance(typeHelper.getClass(), s);
temp = (E[]) o;
for (int i = 0; i < list.size(); i++)
Array.set(temp, i, list.get(i));
}
catch (Exception e)
{return null;}
return temp;
}
サンプル:
String[] s = arrayListToArray(stringList);
Long[] l = arrayListToArray(longList);
私は答えを得ました...これは完全にうまく機能しているようです
public int[] test ( int[]b )
{
ArrayList<Integer> l = new ArrayList<Integer>();
Object[] returnArrayObject = l.toArray();
int returnArray[] = new int[returnArrayObject.length];
for (int i = 0; i < returnArrayObject.length; i++){
returnArray[i] = (Integer) returnArrayObject[i];
}
return returnArray;
}