不,一旦创建,就无法更改数组的大小。你要么必须分配比你认为需要的更大的大小,要么接受必须重新分配它的开销,这需要增加它的大小。这样做时,你将不得不分配一个新的数据,并将数据从旧数据复制到新数据:
int oldItems[] = new int[10];for (int i=0; i<10; i++) { oldItems[i] = i+10;}int newItems[] = new int[20];System.arraycopy(oldItems, 0, newItems, 0, 10);oldItems = newItems;
如果你遇到这种情况,我强烈建议你改用Java Collections。特别是ArrayList实质上是包装一个数组,并根据需要照顾增长数组的逻辑:
List<xClass> mysclass = new ArrayList<xClass>();myclass.add(new xClass());myclass.add(new xClass());
通常
ArrayList,出于多种原因,无论如何,对于数组来说,a是一个更好的解决方案。一方面,数组是可变的。如果你的班级做到了这一点:
class Myclass { private int items[]; public int[] getItems() { return items; }}
你创建了一个问题,因为呼叫者可以更改你的私人数据成员,这会导致各种防御性复制。将此与列表版本进行比较:
class Myclass { private List<Integer> items; public List<Integer> getItems() { return Collections.unmodifiableList(items); }}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)