Незважаючи на те, що це не пряма відповідь на питання, це доповнення до аргументу .length
vs. .size()
Я досліджував щось, пов’язане з цим питанням, тому коли я натрапив на нього, я помітив, що тут наводиться визначення
Кінцева довжина поля, яка містить кількість компонентів масиву .
не "точно" правильно.
Довжина поля містить кількість доступних місць для розміщення компонента, а не кількість компонентів, присутніх у масиві. Таким чином, він представляє загальну доступну пам'ять, виділену на цей масив, а не скільки заповненої пам'яті.
Приклад:
static class StuffClass {
int stuff;
StuffClass(int stuff) {
this.stuff = stuff;
}
}
public static void main(String[] args) {
int[] test = new int[5];
test[0] = 2;
test[1] = 33;
System.out.println("Length of int[]:\t" + test.length);
String[] test2 = new String[5];
test2[0] = "2";
test2[1] = "33";
System.out.println("Length of String[]:\t" + test2.length);
StuffClass[] test3 = new StuffClass[5];
test3[0] = new StuffClass(2);
test3[1] = new StuffClass(33);
System.out.println("Length of StuffClass[]:\t" + test3.length);
}
Вихід:
Length of int[]: 5
Length of String[]: 5
Length of StuffClass[]: 5
Однак, .size()
властивість ArrayList
цього елемента дає кількість елементів у списку:
ArrayList<Integer> intsList = new ArrayList<Integer>();
System.out.println("List size:\t" + intsList.size());
intsList.add(2);
System.out.println("List size:\t" + intsList.size());
intsList.add(33);
System.out.println("List size:\t" + intsList.size());
Вихід:
List size: 0
List size: 1
List size: 2