Java では、最速のソリューションを下回っています。
public convert(ArrayList<Integer> IntegerList) {
int s = IntegerList.size();
int[] intArray = new int[s];
for (int i = 0; i < s; i++) {
intArray[i] = IntegerList.get(i).intValue();
}
}
?
Java では、最速のソリューションを下回っています。
public convert(ArrayList<Integer> IntegerList) {
int s = IntegerList.size();
int[] intArray = new int[s];
for (int i = 0; i < s; i++) {
intArray[i] = IntegerList.get(i).intValue();
}
}
?
最速の方法は、そもそもを使用しないことArrayList<Integer>
です。TIntArrayList
どちらが int[] をラップするか、最初から a を使用してみてくださいint[]
。
何らかの理由で ArrayList を使用する必要があり、それを修正できない場合は、機能する方法が必要であり、パフォーマンスはそれほど重要ではありません。
int[] ints = new int[list.size()];
for(int i=0, len = list.size(); i < len; i++)
ints[i] = list.get(i);
プレーンなJavaで現在持っているよりも優れたソリューションは考えられません。ただし、Guavaを使用すると、おそらく単純化できます。
public convert(List<Integer> list) {
int[] ar = Ints.toArray(list); //Ints is the class from Guava library
}
public void convert(ArrayList<Integer> IntegerList) {
int[] intArray = new int[IntegerList.size()];
int count = 0;
for(int i : IntegerList){
intArray[count++] = i;
}
}
UPDATE : Q. foreach ループは、通常の for ループよりも高速/優れている/異なるのですか?
A.こちら
Integer[] intArray = IntegerList.toArray(new Integer[IntegerList.size()]);