1.hasNext
boolean hasNext()如果仍有元素可以迭代,则返回 true。(换句话说,如果 next 返回了元素而不是抛出异常,则返回 true)。
返回:
如果迭代器具有多个元素,则返回 true。
2.next
E next()返回迭代的下一个元素。
返回:
迭代的下一个元素。
抛出:
NoSuchElementException - 没有元素可以迭代。
public Object next() {
checkForComodification();
try {
Object next = get(cursor);
lastRet = cursor++;
return next;
} catch(IndexOutOfBoundsException e) {
checkForComodification();
throw new NoSuchElementException();
}
}
[color=red](1)方法next()返回的是索引为cursor的元素,然后修改cursor和lastRet的值.
(2) int cursor = 0;
int lastRet = -1;
cursor是下一次next()调用时元素的位置,第一次调用next()将返回索引为0的元素。lastRet记录上一次游标所在位置,因此它总是比cursor少1.[/color]
实例:
import java.util.*;
ArrayList List = new ArrayList();
for( int i=0;i<10;i++ ){ //给数组增加10个Int元素
List.add(i+"T");
}
Iterator t = List.iterator(); //迭代遍历元素
int b=0;
while(t.hasNext()){
b++;
String s = (String)t.next();
System.out.println("第"+b+"个"+s);
}
运行结果:
第1个0T
第2个1T
第3个2T
第4个3T
第5个4T
第6个5T
第7个6T
第8个7T
第9个8T
第10个9T
boolean hasNext()如果仍有元素可以迭代,则返回 true。(换句话说,如果 next 返回了元素而不是抛出异常,则返回 true)。
返回:
如果迭代器具有多个元素,则返回 true。
2.next
E next()返回迭代的下一个元素。
返回:
迭代的下一个元素。
抛出:
NoSuchElementException - 没有元素可以迭代。
public Object next() {
checkForComodification();
try {
Object next = get(cursor);
lastRet = cursor++;
return next;
} catch(IndexOutOfBoundsException e) {
checkForComodification();
throw new NoSuchElementException();
}
}
[color=red](1)方法next()返回的是索引为cursor的元素,然后修改cursor和lastRet的值.
(2) int cursor = 0;
int lastRet = -1;
cursor是下一次next()调用时元素的位置,第一次调用next()将返回索引为0的元素。lastRet记录上一次游标所在位置,因此它总是比cursor少1.[/color]
实例:
import java.util.*;
ArrayList List = new ArrayList();
for( int i=0;i<10;i++ ){ //给数组增加10个Int元素
List.add(i+"T");
}
Iterator t = List.iterator(); //迭代遍历元素
int b=0;
while(t.hasNext()){
b++;
String s = (String)t.next();
System.out.println("第"+b+"个"+s);
}
运行结果:
第1个0T
第2个1T
第3个2T
第4个3T
第5个4T
第6个5T
第7个6T
第8个7T
第9个8T
第10个9T