5

所以错误信息是这样的:

Exception in thread "main" java.lang.IndexOutOfBoundsException: Index: 0, Size: 0
at java.util.ArrayList.rangeCheck(Unknown Source)
at java.util.ArrayList.get(Unknown Source)
at FcfsScheduler.sortArrival(FcfsScheduler.java:77)
at FcfsScheduler.computeSchedule(FcfsScheduler.java:30)
at ScheduleDisks.main(ScheduleDisks.java:33)

我的代码为

public void sortArrival(List<Request> r)
{
    int pointer = 0;
    int sProof = 0;
    while(true)
    {
        if(r.get(pointer).getArrivalTime()<r.get(pointer+1).getArrivalTime())
        {
            Request r1 = r.get(pointer);
            Request r2 = r.get(pointer+1);
            r.set(pointer, r2);
            r.set(pointer+1, r1);
        }
        else
        {
            sProof++;
        }
        ++pointer;
        if(pointer>r.size()-2)
        {
            pointer=0;
            sProof=0;
        }
        if(sProof>=r.size()-2)
        {
            break;
        }
    }
}

错误在

if(r.get(pointer).getArrivalTime()<r.get(pointer+1).getArrivalTime())

但我认为在指针递增后用代码检查数组索引是否正常。它是数组越界异常还是其他?通常,错误是ArrayIndexOutOfBoundsException当它是数组时。这里似乎有什么问题?

4

3 回答 3

6

java.lang.IndexOutOfBoundsException:索引:0,大小:0

数组列表为空。它不包含任何元素。

Index: 0, Size: 0.

你正在尝试访问它。所以你得到IndexOutOfBoundsException.

if(r.size() == 0) && r.size() < pointer + 1)   //If ArrayList size is zero then simply return from method.
  return;
于 2013-03-17T15:42:15.803 回答
5

您正在传入一个空数组。您应该对输入进行一些验证

if (r == null || r.size()==0){
   throw new RuntimeException("Invalid ArrayList");
}
于 2013-03-17T15:44:58.937 回答
0

您的数组大小为 0,您应该正确初始化它以便对其进行迭代。

于 2013-03-17T16:42:19.597 回答