集合——迭代器Iterator

本文介绍了Java集合类如何使用for each循环遍历,并详细讲解了迭代器(Iterator)模式。内容包括集合类实现Iterable接口的重要性,以及Iterator在遍历集合中的作用。通过实例展示了如何自定义集合类并实现Iterator,以支持for each循环。同时,讨论了使用Iterator模式的优点,如统一访问模型和隐藏集合内部结构。

Java的集合类都可以使用for each循环遍历,List,Set,Queue会迭代每个元素,Map会迭代每个key;

List<String> list = List.of("a","b","c");
for(String s : list){
    System.out.println(s);
}

实际上Java编译器并不知道如何遍历List,上述编码能够编译通过,只是因为编译器把for each循环通过Iterator改写成了普通的for循环:

for(Iterator<String> it = list.iterator(); it.hasNext(); ){
    System.out.println(it.next());
}

把这种通过Iterator对象遍历集合的模式成为迭代器;

如果要编写一个集合类,想要使用for each循环,需要满足:

  • 集合类实现Iterable接口,该接口要求返回一个Iterator对象
  • 用Iterator对象迭代集合内部数据
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class Demo01{
	public static void main(String[] args) {
		ReverseList<String> sl = new ReverseList<>();
		sl.add("apple");
		sl.add("orange");
		sl.add("pear");
		sl.add("banana");
		sl.add("watermelon");
		for(String s : sl) {
			System.out.println(s);
		}
	}
}


class ReverseList<T> implements Iterable<T>{
	
	private List<T> list = new ArrayList<>();
	
	public void add(T t) {
		list.add(t);
	}

	@Override
	public Iterator<T> iterator() {
		// TODO 自动生成的方法存根
		return new Iterator<T>() {
			
			int index = list.size();

			@Override
			public boolean hasNext() {
				// TODO 自动生成的方法存根
				return index>0;
			}

			@Override
			public T next() {
				// TODO 自动生成的方法存根
				index--;
				return list.get(index);
			}
			
		};
	}
	
}

watermelon
banana
pear
orange
apple

 ReverseList类实现了Iterable接口,内部以ArrayList的格式存储数据,这里只添加了add()方法,实现Iterable接口必须重写iterator()方法,返回一个Iterator对象,用内部类实现。

Iterator是一种抽象的数据访问模型,使用Iterator模式进行迭代的好处有:

  • 对任何集合都采用同一种访问模型
  • 调用者对集合内部结构一无所知
  • 集合类返回的Iterator对象知道如何迭代
  • java提供了标准的迭代器模型,即集合类实现java.util.Iterable接口,返回java.util.Iterator实例。

参考:廖雪峰Java教程

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值