当前位置: 首页 > 面试题库 >

ArrayList的初始容量和IndexOutOfBoundsException [重复]

赵晟睿
2023-03-14
问题内容

考虑以下示例代码:

List<String> myList = new ArrayList<String>(7);
myList.add(5, "Hello");
myList.removeAll(Collections.singleton(null));

System.out.println(myList.size() + " objects:" );
for (String s : myList) {
    System.out.println("\t" + s);
}

myList 初始化时的初始容量为7,然后下一行尝试将字符串“ Hello”添加到位置5。这将引发IndexOutOfBoundsException:

线程“主”中的异常java.lang.IndexOutOfBoundsException:索引:5,大小:0

我查看了有关ArrayList的“初始容量”的含义的问题。我知道这个特定的构造函数正在为7个String元素分配空间,如果我们尝试向列表中添加8个元素,则必须分配更多的空间。

明白的是,为什么它不创建一个大小为7的“空”列表,每个索引都为空值,类似于我们声明时会发生的情况String[] myArray = newString[7]。我回想起ArrayList是Java对动态数组的实现,因此我希望有类似的行为。如果我在声明时实际上没有空间分配7个字符串newArrayList<String>(7),实际上是什么情况?


问题答案:

我不明白的是,为什么它不创建一个大小为7的“空”列表,每个索引都为空值,类似于我们声明String [] myArray = new String
[7]时的情况。

在某些情况下这将是有用的……而在另一些情况下则没有用。很多时候,你有一个 上限 ,你要创建(或至少是猜测)列表的大小,但你填充它…你
希望有一个清单,然后有错误的大小。 ..因此,您必须在“设置”值时维护索引,然后再设置大小。

我回想起学习ArrayList是Java对动态数组的实现的情况,因此我希望有类似的行为。

不,真的不是。这是一个列表,可以调整大小并在幕后 使用 数组。尽量不要将其视为数组。

如果在声明new时实际上没有空间分配7个字符串ArrayList<String>(7),实际上发生了什么?

确实 有7个字符串引用的空间。该 缓冲区 的大小(即容量)至少为7,但 逻辑 列表的大小仍然是0
-你还没有添加任何东西给它。就像您有一张足够长的纸可以打印7行,但是您还没有写任何东西一样。

如果您 需要 一个预填充列表,则可以轻松地编写一种创建方法:

public static List<T> createPrefilledList(int size, T item) {
    ArrayList<T> list = new ArrayList<T>(size);
    for (int i = 0; i < size; i++) {
        list.add(item);
    }
    return list;
}


 类似资料:
  • 问题内容: 当我做 Java给了我 有没有一种简单的方法可以预先保留ArrayList的大小,然后像数组一样立即使用索引? 问题答案: 这是来源: 构造函数: 您致电: 电话: 它可能很微妙,但是当您调用构造函数时,尽管初始化了an ,但您并未初始化。因此,从中,您会得到,因为它是0。因此,您可以使用(在您的情况下,将类型添加到列表的末尾)来代替使用,而这不会发生。或者,如果适合您,则可以按照另一

  • 问题内容: 我有一些代码引发IndexOutOfBoundsException异常烦人的问题,我真的不明白为什么。logcat指向以下代码的“ addTimetableItem”,这将无法进一步说明: “ sortedFridayTimes”是一个包含我自己的“时间表条目”对象的ArrayList,我已经对其进行了排序。首先检查大小,以查看是否有任何对象,然后检查是否存在“ insertDay”,

  • 为什么我可以初始化ArrayList,如下所示: 但在使用时出错:

  • 问题内容: 我应该传递什么值来为N个项目创建有效的/ 基于结构的结构? 在中,有效数字为N(N已假定未来增长)。a的参数应该是什么?((int)(N * 0.75d),0.75d)?更多?减?更改负载系数有什么影响? 问题答案: 关于负载因子,我将简单引用HashMap javadoc : 通常,默认负载因子(.75)在时间和空间成本之间提供了很好的折衷。较高的值会减少空间开销,但会增加查找成本(