Java-Iterator迭代器

迭代指的是重复的过程,这个接口就是来定义被重复执行的一个过程的标准。为啥需要这个东西呢?Collection的两个子类List和Set,在迭代List和Set时,使用的方式不同,List用有迭代因子来进行迭代,Set用for-each迭代,两个容器的迭代方式不同,为了统一,使用Iterator迭代器,对List和Set统一进行迭代。

单例集合实现了Iterator接口,在该接口中包含一个名为iterator的抽象方法,所有实现了Collection接口的容器类对该方法做了具体实现。iterator方法会返回一个Iterator接口类型的迭代器对象。

在Iterator对象中使用移动游标的方式实现迭代处理

Java-Iterator迭代器_第1张图片

Iterator接口定义了如下方法:

  • boolean hasNext(); //判断游标当前位置是否有元素,如果有返回true,否则返回false;

  • Object next(); //获取当前游标所在位置的元素,在执行完next后操作只能执行一次;

  • void remove(); //删除游标当前位置的元素,在执行完next后该操作只能执行一次;

1.迭代List接口容器

import java.util.List;
import java.util.*;
public class IteratorListTest {
	public static void main(String[] args) {
		//实例化
		List list = new ArrayList<>();
		list.add("a");
		list.add("b");
		list.add("c");
		//获取元素
		//获取迭代器对象,迭代器决定如何获取元素,没有循环能力
		Iterator iterator =list.iterator();
		//方式一,在迭代器中通过while循环获取元素
		while(iterator.hasNext()) {
			String value = iterator.next();
			System.out.println(value);
		}
		System.out.println("---------------");
		//方式二,在迭代器中,通过for循环获取元素
		for(Iterator it = list.iterator();it.hasNext();) {
			String value = it.next();
			System.out.println(value);
		}	
	}
}

2.迭代Set容器接口

import java.util.*;    //以前是要用for-each来实现的
public class IteratorSetTest {
	public static void main(String[] args) {
		//实例化Set类型的容器
		Set set = new HashSet<>();
		set.add("a");
		set.add("b");
		set.add("c");
		//获取迭代器对象
		Iterator iterator = set.iterator();
		//方式一,通过while循环
		while(iterator.hasNext()) {
			String value = iterator.next();
			System.out.println(value);
		}
		System.out.println("----------");
		//方式二,for循环
		for(Iterator it = set.iterator();it.hasNext();) {
			String value = it.next();
			System.out.println(value);
		}
		
	}
}

3.在迭代器中删除元素

//这里随便写写吧
import java.util.*;
public class IteratorRemoveTest {
	public static void main(String[] args) {
		List list = new ArrayList<>();
		list.add("a");
		list.add("b");
		list.add("c");
		list.add("d");
		int flag = -1;
		for(int i=0;i-1) {   //在外部删除指定元素
			list.remove(flag);
		}
	}
}

你可能感兴趣的:(java,迭代器,List,Set)