通过 ArrayList 进行反向迭代给出 IndexOutOfBoundsException [英] Reverse iteration through ArrayList gives IndexOutOfBoundsException

查看:23
本文介绍了通过 ArrayList 进行反向迭代给出 IndexOutOfBoundsException的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

当我反向迭代一个 ArrayList 时,我得到一个 IndexOutOfBoundsException.我尝试进行前向迭代,没有问题.我期望并知道列表中有五个元素.代码如下:

When I reverse iterate over an ArrayList I am getting a IndexOutOfBoundsException. I tried doing forward iteration and there is no problem. I expect and know that there are five elements in the list. The code is below:

Collection rtns = absRtnMap.values();
List list = new ArrayList(rtns);
Collections.sort(list);

for(int j=list.size();j>0;j=j-1){
  System.out.println(list.get(j));
}

<小时>

前向迭代 - 工作正常,但对我没有用:


Forward iteration - which is working fine, but not useful for me:

for(int j=0;j<list.size();j++){
    System.out.println(list.isEmpty());
    System.out.println(list.get(j));
} // this worked fine

<小时>

错误:

Exception in thread "Timer-0" java.lang.IndexOutOfBoundsException: Index: 3, Size: 3
    at java.util.ArrayList.RangeCheck(Unknown Source)
    at java.util.ArrayList.get(Unknown Source)
    at model.Return.getReturnMap(Return.java:61)
    at controller.Poller$1.run(Poller.java:29)
    at java.util.TimerThread.mainLoop(Unknown Source)
    at java.util.TimerThread.run(Unknown Source)

此外,如果有人知道更好的反向迭代习惯用法,我很乐意尝试一下.

Also if anyone knows of a better idiom for reverse iteration I would be happy to try that out.

推荐答案

list.size() - 1 开始迭代,因为数组(或 ArrayList)元素是从 0 到小于列表大小的 1 编号.这是一个相当标准的习语:

Start the iteration at list.size() - 1 because array (or ArrayList) elements are numbered from 0 up through 1 less than the size of the list. This is a fairly standard idiom:

for (int j = list.size() - 1; j >= 0; j--) {
    // whatever
}

请注意,您的前向迭代有效,因为它在之前到达 list.size() 之前停止.

Note that your forward iteration works because it stops before reaching list.size().

这篇关于通过 ArrayList 进行反向迭代给出 IndexOutOfBoundsException的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆