迭代器方法:(把迭代器想象成抓娃娃机的爪子)
hasNext() 问是否有元素可遍历,如果有元素可以遍历,返回true,否则返回false
工作原理:这一个迭代的过程是这样的,获取到迭代器时候迭代器有个指针,初始时
指向集合的第一个元素。然后一个个的按顺序遍历,最后移动到集合中没有元素了。
(这是看源代码看的)
next() 获取元素//如果判断有那么就用该方法开始抓,一次只能抓一个
工作原理:
void remove() 移除迭代器最后一次返回的元素(看下面代码
import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator; public class EX10 { public static void main(String[] args) { Collection c = new ArrayList();
c.add("狗娃");
c.add("狗剩");
c.add("铁蛋"); Iterator it = c.iterator();//返回一个迭代器
System.out.println("师范有元素可以遍历? " + it.hasNext());
while(it.hasNext()){
System.out.println("获取元素:" + it.next());//一次一个
} System.out.println();
Collection c1 = new ArrayList();
c1.add("狗娃");
c1.add("狗剩");
c1.add("铁蛋"); Iterator it1 = c1.iterator();
while (it1.hasNext()){
it1.next();
it1.remove();
}
System.out.println("移除之后的结果是:" + c1);
//最后输出的是空集合 /*为什么iterator() 方法返回的是一个接口类型,为什么接口又可以调用方法?
iterator 实际上是返回iterator 接口的实现类方法。
实际上是多态的应用:
nterface Moeny{
public void print();
} class Worker implements Moeny{
@Override
public void print() {
System.out.println("工人正在赚钱");
}
} class Demo {
public static void main(String[] args) {
Moeny m = test();
m.print();
}
public static Worker test(){
return new Worker();
}
} */
}
}