Iterator接口
迭代器(Iterator)主要用来操作java里的集合对象(collection)。迭代器提供了统一的语法进行集合对象(collection)遍历操作,无需关心集合对象的内部实现方式。java提供了一个迭代器接口Iterator。Iterator只能向前移动,无法回退。
java的迭代器接口的申明如下:
public interface Iterator<E> {
boolean hasNext();
E next();
void remove();
}
从上面的接口代码可以看到,Iterator接口只有三个无参方法。
方法 | 返回值 | 异常 | 说明 |
---|---|---|---|
hasNext | bool | 无 | 判断是否还有下一个对象,如果有,则返回true,否则false |
next | E | NoSuchElementException | 返回集合的下个值,此方法只能在hasNext方法返回true时调用 |
remove | void | IllegalStateException | 删除集合的当前值,此方法也只能在hasNext方法返回true时调用 |
Iterable接口
jdk1.5之后,添加了Iterable接口用于支持foreach的循环。Iterable接口只有一个方法,就是iterator()方法,返回集合的Iterator对象。所有实现Iterable接口的集合都可以使用foreach循环进行遍历。
Iterable的源码如下:
public interface Iterable<T> {
Iterator<T> iterator();
}
Iterator与Iterable的区别
从上面的介绍可以看到Iterator接口是提供了一种统一的遍历集合元素的方式。使用Iterator对象可以不用关心具体集合对象的具体类型和内部实现,统一使用Iterator对象的接口方法就可以遍历集合。
Iterable接口,是为了foreach循环设计的。Iterable接口表示,集合可以返回Iterator对象。最终还是使用Iterator进行遍历。
Set的遍历和删除
java的集合框架里,Set是指不能包含重复元素的集合。Set对象是可以使用Iterator对象进行遍历操作的,同时Set集合也继承了Iterable接口,所以支持foreach循环。使用例子如下:
public class IteratorTest {
static void testSet(){
Set<Integer> set = new HashSet<>();
set.add(1);
set.add(2);
set.add(3);
set.add(3);
Iterator<Integer> setIter = set.iterator();
while (setIter.hasNext()){
if (setIter.next() == 2){
setIter.remove();
}
}
for (int i:set){
System.out.println(i);
}
}
public static void main( String[] args ) {
testSet();
}
}
在上面的例子中,使用Iterator对象遍历了Set集合,同时删除了为2的元素,使用foreach循环,最终输出
1
3
List的遍历并删除
java的集合框架里,List和Set的不同之处,在于List能包含重复元素,能使用下标进行遍历。List对象也是可以使用Iterator对象进行遍历操作的,同时List集合也继承了Iterable接口,所以支持foreach循环。使用例子如下:
public class IteratorTest {
static void testList(){
List<Integer> testList = new ArrayList<>();
testList.add(1);
testList.add(2);
testList.add(3);
Iterator<Integer> iter = testList.iterator();
while (iter.hasNext()){
if (iter.next() == 2){
iter.remove();
}
}
for (int i:testList){
System.out.println(i);
}
}
public static void main( String[] args ) {
testList();
}
}
在上面的例子中,使用Iterator对象遍历了List集合,同时删除了为2的元素,使用foreach循环,最终输出
1
3
虽然List集合也能使用下标进行遍历循环,但如果想在遍历中删除满足某些条件的对象,则使用Iterator是最方便的。