学习笔记,仅供参考,有错必纠
集合
迭代器遍历
- 迭代器概述
集合是用来存储元素的,存储的元素需要查看,那么就需要迭代(遍历) 。
Iterator类
Iterator类是在java.util包下的一个类,用的时候需要导包,它是一个接口,不能被实例化。
- hasNext方法
boolean hasNext()
如果仍有元素可以迭代,则返回 true。(换句话说,如果 next 返回了元素而不是抛出异常,则返回 true)。
- next方法
E next()
返回迭代的下一个元素。
Collection类的iterator方法
Iterator<E> iterator()
返回在此 collection 的元素上进行迭代的迭代器。关于元素返回的顺序没有任何保证(除非此 collection 是某个能提供保证顺序的类实例)。
迭代器原理
迭代器是对集合进行遍历,而每一个集合内部的存储结构都是不同的,所以每一个集合存和取都是不一样,那么就需要在每一个类中定义hasNext()
和next()
方法,这样做是完全OK的,但是会让整个集合体系过于臃肿,迭代器是将这样的方法向上抽取出接口,然后在每个类的内部定义自己迭代方式,这样做的好处有二:第一,规定了整个集合体系的遍历方式都是hasNext()和next()方法;第二,代码有底层内部实现,使用者不用管怎么实现的,会用即可。
举个例子
package com.guiyang.restudy3;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
import com.guiyang.bean.Student;
@SuppressWarnings({ "rawtypes", "unchecked" })
public class D3Iterator {
public static void main(String[] args) {
Collection c = new ArrayList();
c.add(new Student("张三", 23)); //Object obj = new Student("张三",23);
c.add(new Student("李四", 24));
c.add(new Student("王五", 25));
c.add(new Student("赵六", 26));
//获取迭代器
Iterator it = c.iterator();
//java.util.Iterator
while(it.hasNext()) {
//System.out.println(it.next());
Student s = (Student)it.next(); //向下转型
System.out.println(s.getName() + "..." + s.getAge());
}
}
}
输出:
张三...23
李四...24
王五...25
赵六...26