Java Iterator接口

在程序开发中,经常需要遍历集合中的所有元素。针对这种需求,Java专门提供了一个接口IteratorIterator接口也是集合中的一员,但它与CollectionMap接口有所不同。Collection接口与Map接口主要用于存储元素,而Iterator主要用于迭代访问(即遍历)Collection中的元素,因此Iterator对象也被称为迭代器(通用遍历集合的方式)。

 迭代器遍历集合
 Iterator集合对象.iterator()  获取迭代器对象
成员方法:

boolean hasNext()判断是否还有元素
E next()获取当前元素
void remove()删除当前元素
  


集合遍历方式
方式1
public class inter {
	public static void main(String[]args) {
	
ArrayList<String>list=new ArrayList<>() ;
list.add("张三");
list.add("李四");
list.add("王五");
for(int i=0;i<list.size(); i++)//List集合有索引,可以for循环
{
String s=list.get(i) ;
System.out.println(s);
}

	}
}

在这里插入图片描述

迭代器通用遍历方式
/*
 迭代器遍历集合
 Iterator集合对象.iterator()  获取迭代器对象
成员方法:

boolean hasNext()判断是否还有元素
E next()获取当前元素
void remove()删除当前元素*/

public class inter {
	public static void main(String[]args) {
	
ArrayList<String>list=new ArrayList<>() ;
list.add("张三");
list.add("李四");
list.add("王五");
while(it.hasNext())
{
String str=it.next() ;
System.out.print(str);
}

首先使用hasNext()方法判断集合中是否存在下一个元素,如果存在,则调用next()方法将元素取出,否则说明已到达了集合末尾,停止遍历元素。需要注意的是,在通过next()方法获取元素时,必须保证要获取的元素存在,否则,会抛出NoSuchElementException异常。

package sk;

import java.util.ArrayList;
import java.util.Iterator;

/*
 迭代器遍历集合
 Iterator集合对象.iterator()  获取迭代器对象
成员方法:

boolean hasNext()判断是否还有元素
E next()获取当前元素
void remove()删除当前元素*/
public class inter {
	public static void main(String[]args) {
	
ArrayList<String>list=new ArrayList<>() ;
list.add("张三");
list.add("李四");
list.add("王五");
//Concurrent Modification Exception并发修改异常
Iterator<String> it=list.iterator();
while(it.hasNext())
{
	String str=it.next();
	if("李四".equals(str))
	{//Concurrent Modification Exception并发修改异常Iterator<String>it=list.iterator() ;
	//list.remove(str);若删除的是张三,则出现并发修改异常问题
		it.remove();//用迭代器集合中的对象调用删除函数,从而解决并发修改异常问题
	
	}
}
System.out.println(list);
	
}
}

在这里插入图片描述
上图中,在调用Iterator的next()方法之前,迭代器的索引位于第一个元素之前,不指向任何元素,当第一次调用迭代器的next()方法后,迭代器的索引会向后移动一位,指向第一个元素并将该元素返回,当再次调用next()方法时,迭代器的索引会指向第二个元素并将该元素返回,以此类推,直到hasNext()方法返回false,表示到达了集合的末尾,终止对元素的遍历。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值