目录
- 迭代器的概念
- 迭代器的使用步骤(重点)
- 迭代器的实现原理
- 增强for循环(for each循环)
迭代器的概念
- java。util.Iterator接口:迭代器(对集合进行遍历)
- 集合分为很多种,每种集合存储和取出数据的方式都不一样。而且由于有些集合是没有索引值的,因此不能简单的用for循环遍历。
- 迭代器是一种Collection通用的,从集合中取出元素的方式。
- 在取出元素之前,先要判断集合中有没有元素,如果有,就把这个元素取出来,再继续判断,如果还有就再继续取出来。一直把集合中所有的元素全部取出来。这种取出方式的专业术语就叫做迭代。
- 有两个常用的方法:
- boolean hasNext():判断集合中还有没有下一个元素可以迭代。如果仍有元素可以迭代,则返回true。如果没有则返回false
- E next(): 返回迭代的下一个元素(即取出集合的下一个元素,注意取出元素时相当于从第-1个元素开始取的)
- 注意:Iterator迭代器是一个接口,我们无法直接使用,需要使用Iterator接口的实现类对象,获取实现类的方式比较特殊。Collection接口中有一个方法,叫做iterator(),这个方法返回的就是迭代器的实现类对象
- Iterator<E> iterator()返回在此collection的元素上进行迭代的迭代器
迭代器的使用步骤(重点)
- 使用集合中的方法iterator()获取迭代器的实现类对象,使用Iterator接口接收(多态)
- 注意:Iterator<E>接口也是有泛型的,迭代器的泛型跟着集合走,集合是什么泛型,迭代器就是什么泛型
- 使用Iterator接口中的hasNext方法判断还有没有下一个元素
- 使用Iterator接口中的next方法取出集合中的下一个元素
Collection<String> coll = new ArrayList<>();
coll.add("jack");
coll.add("Mack");
coll.add("John");
coll.add("Tom");
System.out.println(coll);
//多态 接口 实现类对象
Iterator<String> iterator = coll.iterator(); //重点
while (iterator.hasNext()){ //判断是否还有下一个元素
System.out.println(iterator.next()); //返回下一个元素
}
输出:
[jack, Mack, John, Tom]
jack
Mack
John
Tom
迭代器的实现原理
- Collection coll = new ArrayList<>();
- 获取迭代器的实现类对象,并且会把指针指向集合的-1位置
- iterator.hasNext()
- 判断集合中还有没有下一个元素
- iterator.next()
- 取出下一个元素
- 把指针移动至下一位
增强for循环(for each循环)
- 增强for循环(也称for each循环)是JDK 1.5以后出来的一个高级for循环,专门用来遍历数组和集合的。它的内部原理其实是一个Iterator迭代器。所以在遍历的过程中,不能对集合中的元素进行增删操作。
- 使用的是for循环的格式,简化了for循环的书写
- Collection<E> extends Iterable<E> :Collection接口继承了一个叫做Iterable接口,该接口的作用是允许对象成为“foreach”语句的目标。所有的单列集合都可以使用增强for循环
- 格式:
for(集合/数组的数据类型 变量名 : 集合名/数组名){
sout(变量名);
}
Collection<String> coll = new ArrayList<>();
coll.add("jack");
coll.add("Mack");
coll.add("John");
coll.add("Tom");
System.out.println(coll);
//使用增强for循环遍历集合
for (String s : coll) {
System.out.println(s);
}
输出:
[jack, Mack, John, Tom]
jack
Mack
John
Tom