Универсальный класс Iterator - PullRequest
0 голосов
/ 01 марта 2012

У меня есть три класса, это Lister, ObjectSortedList и SortedListProgram.У меня проблемы с итератором для универсального класса.Что я делаю неправильно?

Это ошибка, которую я получаю:

Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 6
    at objectsortedlist.ObjectSortedList.getData(ObjectSortedList.java:122)
    at objectsortedlist.Lister.hasNext(Lister.java:28)
    at objectsortedlist.SortedListProgram.main(SortedListProgram.java:52)
Java Result: 1

Вот мои уроки:

package objectsortedlist;

import java.util.Iterator;

/**
*
* @author Steven
*/
public class ObjectSortedList<T> implements Cloneable, Iterable<T> {

private T[] data;
private int capacity;

public ObjectSortedList()
{
    final int init_capacity = 10;
    capacity = 0;
    data = (T[])new Object[init_capacity];
}

public ObjectSortedList(int init_capacity)
{
    if(init_capacity < 0)
        throw new IllegalArgumentException("Initial capacity is negative: " + init_capacity);
    capacity = 0;
    data = (T[])new Object[init_capacity];
}

private boolean empty()
{
    if(data.length == 0 || data[0] == null)
        return true;
    else
        return false;
}

public int length()
{
    return capacity;
}

public void insert(T element)
{
    if(capacity == data.length)
    {
        ensureCapacity(capacity * 2 + 1);
    }
    data[capacity] = element;
    capacity++;
}

public boolean delete(T target)
{
    int index;

    if(target == null)
    {
        index = 0;
        while((index < capacity) && (data[index] != null))
            index++;
    }
    else
    {
        index = 0;
        while((index < capacity) && (!target.equals(data[index])))
            index++;
    }

    if(index == capacity)
        return false;
    else
    {
        capacity--;
        data[index] = data[capacity];
        data[capacity] = null;
        return true;
    }
}

private void ensureCapacity(int minCapacity)
{
    T[] placeholder;

    if(data.length < minCapacity)
    {
        placeholder = (T[])new Object[minCapacity];
        System.arraycopy(data, 0, placeholder, 0, capacity);
        data = placeholder;
    }
}

public ObjectSortedList<T> clone()
{
    // Cloning
    ObjectSortedList<T> answer;

    try
    {
        answer = (ObjectSortedList<T>) super.clone();
    }
    catch(CloneNotSupportedException cnse)
    {
        throw new RuntimeException("This class does not implement cloneable.");
    }

    answer.data = data.clone();
    return answer;
}

@Override
public Iterator<T> iterator() 
{
    return (Iterator<T>) new Lister<T>(this, 0);
}

public T getData(int index)
{
    return (T)data[index];
}
}


package objectsortedlist;

import java.util.Iterator;
import java.util.NoSuchElementException;

/**
*
* @author Steven
*/
public class Lister<T> implements Iterator<T>
{
private ObjectSortedList<T> current;
private int index;

public Lister(ObjectSortedList<T> top, int index)
{
    current = top;
    this.index = index;
}

@Override
public boolean hasNext()
{
    return (current.getData(index) == null);
}

@Override
public T next()
{
    T answer;

    if(!hasNext())
        throw new NoSuchElementException("The Lister is empty.");

    answer = current.getData(index+1);
    return answer;
}

@Override
public void remove() {
    throw new UnsupportedOperationException("Don't use this. Use objectsortedlist.SortedList.delete(T target).");
}
}


package objectsortedlist;

import java.util.Scanner;

/**
*
* @author Steven
*/
public class SortedListProgram {

private static Scanner scan = new Scanner(System.in);
private static String[] phraseArray = {"Hullabaloo!", "Jiggery pokery!", "Fantastic!", "Brilliant!", "Clever!", "Geronimo!", "Fish sticks and custard.", "Spoilers!",
         "Exterminate!", "Delete!", "Wibbly-wobbly!", "Timey-wimey!"};
private static Lister<String> print;

public static void main(String args[])
{
    int phraseNo = 0;

    System.out.println("I'm gonna say some things at you, and you're going to like it."
            + " How many things would you like me to say to you? Put in an integer from 1-12, please.");
    try
    {
        phraseNo = Integer.parseInt(scan.nextLine());

        while((phraseNo < 1) || (phraseNo > 12))
        {
            System.out.println("The integer you entered wasn't between 1 and 12. Make it in between those numbers. Please? Pleaseeeee?");
            phraseNo = Integer.parseInt(scan.nextLine());
        }
    }
    catch(NumberFormatException nfe)
    {
        System.out.println("C'mon, why don't you follow directions?");
        phraseNo = 0;
    }

    if(phraseNo == 0);
    else
    {
        ObjectSortedList<String> phrases = new ObjectSortedList<String>(phraseNo);
        for(int i = 0; i < phrases.length(); i++)
        {
            phrases.insert(phraseArray[i]);
        }

        print = new Lister<String>(phrases, phraseNo);
        while(print.hasNext())
            System.out.println(print.next());
    }
}
}

1 Ответ

0 голосов
/ 01 марта 2012

После просмотра вашего кода я обнаружил несколько проблем, вот они:

  1. В вашем классе SortedListProgram в следующем коде phrases.length() будет 0, поэтому он никогда не пойдет в этот цикл.

    ObjectSortedList<String> phrases = new ObjectSortedList<String>(phraseNo);
    for(int i = 0; i < phrases.length(); i++)
    {
        phrases.insert(phraseArray[i]);
    }
    
  2. Более того, в SortedListProgram последовательности вызовов этого класса

    print.hasNext() -> current.getData(index)

    переданный index равен size поля массива data в ObjectSortedList класс и С в индексах массива Java варьируется от zero до array size -1. Таким образом, вы обязаны получить java.lang.ArrayIndexOutOfBoundsException всегда.

Пожалуйста, исправьте ваш код.

...