你可以通过下面的操作来设置数组列表的初始大小
ArrayList<Integer> arr=new ArrayList<Integer>(10);
然而,你不能这样做
arr.add(5, 10);
因为它会导致出界异常。
如果不能访问所分配的空间,那么设置初始大小有什么用呢?
添加函数定义为add(int index, Object element),所以我没有添加到索引10。
你可以通过下面的操作来设置数组列表的初始大小
ArrayList<Integer> arr=new ArrayList<Integer>(10);
然而,你不能这样做
arr.add(5, 10);
因为它会导致出界异常。
如果不能访问所分配的空间,那么设置初始大小有什么用呢?
添加函数定义为add(int index, Object element),所以我没有添加到索引10。
当前回答
我对流的看法。我觉得还是用它比较好
IntStream.generate(i -> MyClass.contruct())
.limit(INT_SIZE)
.collect(Collectors.toList());
可以灵活地设置任何初始值。
其他回答
普通发布版. .
List <Destination\> destinations = Collections.nCopies(source.size(), Destination.class.newInstance());
数组列表的容量和它的大小是不一样的。Size等于ArrayList(以及任何其他List实现)中包含的元素的数量。
容量是底层数组的长度,用于内部存储数组列表的元素,并且总是大于或等于列表的大小。
当调用列表上的set(index, element)时,索引与列表元素的实际数量(=size)相关(在代码中为零,因此抛出AIOOBE),而与数组长度(=capacity)无关(这是特定于ArrayList的实现细节)。
set方法对于所有List实现都是通用的,比如LinkedList,它实际上不是通过数组实现的,而是作为一个链接的条目链实现的。
编辑:实际上使用的是add(index, element)方法,而不是set(index, element)方法,但这里的原理是一样的。
我对流的看法。我觉得还是用它比较好
IntStream.generate(i -> MyClass.contruct())
.limit(INT_SIZE)
.collect(Collectors.toList());
可以灵活地设置任何初始值。
如果你想使用集合。填充(列表,obj);为了用重复的对象填充列表,您可以使用
ArrayList<Integer> arr=new ArrayList<Integer>(Collections.nCopies(10, 0));
这一行将10乘以0复制到数组列表中
现在你的列表中没有元素,所以当索引5不存在时,你不能添加到它。您混淆了列表的容量与其当前大小。
就叫:
arr.add(10)
将整数添加到数组列表中