这是我实现Iterator的内部类:
public class myIterator implements Iterator<Object> {
private int pos = 0;
public boolean hasNext(){
return pos < arrayPal.length;
}
public Object next(){
return arrayPal[pos++];
}
}
在这个内部类所在的类中,DynArray(这是一个对象,它有一个名为arrayPal的内部数组,任何类型的对象,以及一个布尔值,表示数组是否可以存储空值)我想使用迭代器作为我的add方法
public void add( T ele ) {
int counter =0;
int tempIndex =0;
if(ele == null && this.allowed == false){
throw new NullPointerException("This array does not accept null values!");
}
else{
myIterator iterator = new myIterator();
Iterator<T> it = this.iterator();
for(Object o: this.arrayPal){
System.out.print(it.hasNext());
if(it.hasNext() == false && (this.arrayPal.length-1) > counter){
arrayPal[counter+1] = ele;
}
else if (it.hasNext() == false && (arrayPal.length-1) == counter){
//expand the array by quanta
//add the the first newest index
Object[] temp = new Object[this.arrayPal.length + quanta];
for(Object b: this.arrayPal){
temp[tempIndex++] = b;
}
temp[this.arrayPal.length] = ele;
this.arrayPal = temp;
}
counter++;
}
}
然而.hasNext()即使对于列表中的最后一个元素也会保持返回true。为什么是这样?
另外,它不允许我这样做.arrayPal.iterator()它说:
无法在数组类型上调用iterator() 对象[]
为什么不呢?
答案 0 :(得分:2)
您的add
方法获得了一个新的迭代器并多次调用it.hasNext()
。它永远不会调用it.next()
,因此Iterator
会一直指向数组的第一个元素,而hasNext()
将永远不会返回false(假设数组不为空)。