在ArrayIndexOutOfBoundsException中对程序执行结果进行排序

时间:2018-06-09 11:26:28

标签: java sorting java.lang

请考虑以下代码:

import java.io.*; //Sorts by dividing the array in 2 groups then joining them

public class Esercizio29 {static void  join(char[] a, int l, int m, int u) {
    char[] b = new char[u - 1 + 1];
    int i = l, j = m + 1, k = 0;

    while (i <= m && j <= u) 
        if (a[i] <= a[j])
            b[k++] = a[i++];
        else
            b[k++] = a[j++];
    while (i <= m)
        b[k++] = a[i++];
    while (j <= u)
        b[k++] = a[j++];        
    for (k = 0; k <= u - l; k++)
        a[k + l] = b[k];
}
//Sorts the array from l to u
static void sort(char[] a, int l, int u) {
    int m;
    if (l != u) {
        m = (l + u) / 2;
        sort(a,l,m);
        sort(a,m + 1,u);
        join(a,l,m,u);
    }
}



public static void main(String[] args) throws IOException{
    final int N = 16;
    char temp, v[] = new char[N];

    for (int i = 0; i <  N; i++)
        v[i] = (char) System.in.read();
    sort(v, 0, N - 1);
    System.out.println("Vettore ordinato: ");
    for(int i = 0; i < N; i++)
        System.out.print(v[i]);
    System.out.println();
}}

运行此代码后,它给出了我的结果:

Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 1

at Esercizio29.fondi(Esercizio29.java:14)

at Esercizio29.ordina(Esercizio29.java:27)

at Esercizio29.ordina(Esercizio29.java:25)

at Esercizio29.ordina(Esercizio29.java:25)

at Esercizio29.ordina(Esercizio29.java:25)

at Esercizio29.main(Esercizio29.java:39)

这个错误意味着什么,我该如何解决?谢谢。

3 个答案:

答案 0 :(得分:1)

实际上java.lang.ArrayIndexOutOfBoundsException意味着您正在访问大于数组大小的数组元素。

示例:

int[] array = {1,2,3,4};

for(int i=0;i<5;i++){
    System.out.println(array[i]);//when i =4 it will show exception.
}

因为我只为数组分配了4个元素意味着数组大小为4.现在,如果我想访问第5个元素,它将显示运行时异常,因为数组索引以0开头,而数组只有4个元素。在你的情况下在行14您访问的数组元素大于数组大小。因此它导致运行时异常&#34; java.lang.ArrayIndexOutOfBoundsException&#34;

答案 1 :(得分:1)

好吧,ArrayIndexOutOfBoundsException错误意味着您试图访问在数组中找不到的索引 - 在这种情况下索引1(意味着您的数组在第一个(0)索引处包含单个值)。

您的异常是从join方法抛出的,您确实尝试访问单个大小的数组的第二个索引。您没有对您的阵列访问操作伙伴进行完整性检查,我担心这是一种不好的做法...

以下修复程序将使您的代码按预期运行:

public class Esercizio29 {static void  join(char[] a, int l, int m, int u) {
    char[] b = new char[u]; // replaced redundent [u - 1 + 1]
    int i = l, j = m + 1, k = 0;

    while (i <= m && j <= u) 
        if (a[i] <= a[j])
            b[k++] = a[i++];
        else
            b[k++] = a[j++];
    while (i <= m && k < b.length) // integrity check
        b[k++] = a[i++];
    while (j <= u && k < b.length) { // integrity check
        b[k++] = a[j++];  
    }
    for (k = 0; k <= u - l && k < a.length && k < b.length; k++) // integrity checks
        a[k + l] = b[k];
}

答案 2 :(得分:1)

更改此行代码,它将起作用

char[] b = new char[u + 1];

你在哪里做-1 + 1导致ArrayIindexOutOfBounds