Java迭代器(转)(iterator详解以及和for循环的区别)
摘自http://septiny.com/java/2014/09/24/java-iterator-and-for.html
迭代器是一种模式,它可以使得对于序列类型的数据结构的遍历行为与被遍历的对象分离,即我们无需关心该序列的底层结构是什么样子的。只要拿到这个对象,使用迭代器就可以遍历这个对象的内部.
1.Iterator
Java提供一个专门的迭代器«interface»Iterator,我们可以对某个序列实现该interface,来提供标准的Java迭代器。Iterator接口实现后的功能是“使用”一个迭代器.
文档定义:
1 Package java.util; 2 public interface Iterator<E> { 3 boolean hasNext();//判断是否存在下一个对象元素 4 E next(); 5 void remove(); 6 }
2.Iterable
Java中还提供了一个Iterable接口,Iterable接口实现后的功能是“返回”一个迭代器,我们常用的实现了该接口的子接口有: Collection, Deque, List, Queue, Set 等.该接口的iterator()方法返回一个标准的Iterator实现。实现这个接口允许对象成为 For each 语句的目标。就可以通过For each语法遍历你的底层序列。
Iterable接口包含一个能够产生Iterator的iterator()方法,并且Iterable接口被foreach用来在序列中移动。因此如果创建了任何实现Iterable接口的类,都可以将它用于foreach语句中。
文档定义:
1 Package java.lang; 2 3 import java.util.Iterator; 4 public interface Iterable<T> { 5 Iterator<T> iterator(); 6 }
使用Iterator的简单例子
1 import java.util.*; 2 3 public class TestIterator { 4 5 public static void main(String[] args) { 6 7 List list=new ArrayList(); 8 9 Map map=new HashMap(); 10 //初始化list和map的数据 11 for(int i=0;i<10;i++){ 12 13 list.add(new String("list"+i) ); 14 15 map.put(i, new String("map"+i)); 16 17 } 18 19 Iterator iterList= list.iterator();//List接口实现了Iterable接口 20 //循环list 21 while(iterList.hasNext()){ 22 23 String strList=(String)iterList.next(); 24 25 System.out.println(strList.toString()); 26 27 } 28 29 Iterator iterMap=map.entrySet().iterator(); 30 //循环map 31 while(iterMap.hasNext()){ 32 33 Map.Entry strMap=(Map.Entry)iterMap.next(); 34 35 System.out.println(strMap.getValue()); 36 37 } 38 39 } 40 41 }
接口Iterator在不同的子接口中会根据情况进行功能的扩展,例如针对List的迭代器ListIterator,该迭代器只能用于各种List类的访问。ListIterator可以双向移动。添加了previous()等方法.
3 Iterator与泛型搭配
Iterator对集合类中的任何一个实现类,都可以返回这样一个Iterator对象。可以适用于任何一个类。
因为集合类(List和Set等)可以装入的对象的类型是不确定的,从集合中取出时都是Object类型,用时都需要进行强制转化,这样会很麻烦,用上泛型,就是提前告诉集合确定要装入集合的类型,这样就可以直接使用而不用显示类型转换.非常方便.
4.foreach和Iterator的关系
for each是jdk5.0新增加的一个循环结构,可以用来处理集合中的每个元素而不用考虑集合定下标。
格式如下
1 for(variable:collection){ statement; }
定义一个变量用于暂存集合中的每一个元素,并执行相应的语句(块)。collection必须是一个数组或者是一个实现了lterable接口的类对象。
上面的例子使用泛型和forEach的写法:
1 import java.util.*; 2 public class TestIterator { 3 4 public static void main(String[] args) { 5 6 List<String> list=new ArrayList<String> (); 7 8 for(int i=0;i<10;i++){ 9 list.add(new String("list"+i) ); 10 } 11 12 for(String str:list){ 13 System.out.println(str); 14 } 15 16 }
使用for循环时,在循环内使用list.remove()会导致错误,可以使用如下方法:
for(int i = 0; i < list.size();i++){if(true){list.remove(list.get(i));--i;//remove的同时下标跟着减
}
}
可以看出,使用for each循环语句的优势在于更加简洁,更不容易出错,不必关心下标的起始值和终止值。
forEach不是关键字,关键字还是for,语句是由iterator实现的,他们最大的不同之处就在于remove()方法上。
一般调用删除和添加方法都是具体集合的方法,例如:
List list = new ArrayList(); list.add(…); list.remove(…);
但是,如果在循环的过程中调用集合的remove()方法,就会导致循环出错,因为循环过程中list.size()的大小变化了,就导致了错误。 所以,如果想在循环语句中删除集合中的某个元素,就要用迭代器iterator的remove()方法,因为它的remove()方法不仅会删除元素,还会维护一个标志,用来记录目前是不是可删除状态,例如,你不能连续两次调用它的remove()方法,调用之前至少有一次next()方法的调用。
forEach就是为了让用iterator循环访问的形式简单,写起来更方便。当然功能不太全,所以但如有删除操作,还是要用它原来的形式。
4 使用for循环与使用迭代器iterator的对比
效率上的各有有事
采用ArrayList对随机访问比较快,而for循环中的get()方法,采用的即是随机访问的方法,因此在ArrayList里,for循环较快
采用LinkedList则是顺序访问比较快,iterator中的next()方法,采用的即是顺序访问的方法,因此在LinkedList里,使用iterator较快
从数据结构角度分析,for循环适合访问顺序结构,可以根据下标快速获取指定元素.而Iterator 适合访问链式结构,因为迭代器是通过next()和Pre()来定位的.可以访问没有顺序的集合.
而使用 Iterator 的好处在于可以使用相同方式去遍历集合中元素,而不用考虑集合类的内部实现(只要它实现了 java.lang.Iterable 接口),如果使用 Iterator 来遍历集合中元素,一旦不再使用 List 转而使用 Set 来组织数据,那遍历元素的代码不用做任何修改,如果使用 for 来遍历,那所有遍历此集合的算法都得做相应调整,因为List有序,Set无序,结构不同,他们的访问算法也不一样.
Java迭代器(转)(iterator详解以及和for循环的区别)相关推荐
- java mcu 视频会议_详解视频会议终端和MCU的区别
详解视频会议终端和MCU的区别 视频会议终端和MCU都是视频会议系统的核心组成部分之一,但其价格也相对高昂,是整个视频会议系统的主要成本之一.但是不熟悉视频会议系统的人,常常将视频会议终端和MCU无意 ...
- C++:迭代器(STL迭代器)iterator详解
STL迭代器 参考链接:http://c.biancheng.net/view/338.html
- Java Map集合的详解
参考自:Java Map集合的详解 (略有修改) 一,Map 如果程序中存储了几百万个学生,而且经常需要使用学号来搜索某个学生,那么这个需求有效的数据结构就是Map. Map是一种依照键(key)存储 ...
- List逆向遍历、反向遍历--Iterator详解
List逆向遍历.反向遍历–Iterator详解 概述 在使用java集合的时候,都需要使用Iterator.但是java集合中还有一个迭代器ListIterator,在使用List.ArrayLis ...
- java 8 新功能详解_Java 8的8个新功能
java 8 新功能详解 注意:确保还检查了我们的详细教程Java 8 Features – ULTIMATE Guide . Jdk 1.8(又名Java 8)今天发布,这意味着它的通用发布版本已经 ...
- 夯实JAVA基本之一 —— 泛型详解(1):基本使用
前言:无论何时,相信自己. 相关文章: 1.<夯实JAVA基本之一 -- 泛型详解(1):基本使用> 2.<夯实JAVA基本之一--泛型详解(2):高级进阶> 3.<夯实 ...
- Java JUC并发编程详解
Java JUC并发编程详解 1. JUC概述 1.1 JUC简介 1.2 进程与线程 1.2 并发与并行 1.3 用户线程和守护线程 2. Lock接口 2.1 Synchronized 2.2 什 ...
- Java单元测试之JUnit4详解
2019独角兽企业重金招聘Python工程师标准>>> Java单元测试之JUnit4详解 与JUnit3不同,JUnit4通过注解的方式来识别测试方法.目前支持的主要注解有: @B ...
- java -jar 和 -cp详解
java -jar 和 -cp详解 命令行执行程序 假如我们有一个程序,把它打包成Test.jar,如何运行才能成功输出Hello World package com.test; public cla ...
最新文章
- 《Ember.js实战》——2.3 计算属性
- html5初探ppt,HTML5---HTML5初探151019解析.ppt
- Mybatis-增删改查模糊查询分页注解(普通类型参数、引用类型参数、Map类型参数)
- php结合redis实现高并发下的抢购、秒杀功能
- 模板:2-SAT问题
- 程序员都很老实?你错了,其实程序员真实的样子是这样的
- python3 manage.py runserver 0.0.0.0:8000 没反应
- 操作xml文档的常用方式
- 学习笔记之TCP/IP协议分层与OSI參考模型
- heidisql与 MySQL区别,heidisql怎么使用 MySQL可视化工具heidisql安装使用教程
- Fabric开发(三) Ubuntu20.04.1快速搭建Fabric1.4.3 (排雷版)
- viser 饼图修改颜色
- “5G+”发展论坛暨“金帽子”年度盛典圆满结束,共同探讨5G背景下网安技术发展和前沿趋势
- k8s学习笔记5-部署和应用ingress-nginx-controller(v1.3.0)
- 【答学员问】有没有三十岁以上大龄转行的学员,我想跟他聊聊?
- 【淘宝经验分享】新开店铺如何提升流量
- 视频会议十大开源项目
- it工种分类_什么是运维?运维工种有哪些
- 为什么建议大家使用 Linux 开发?爽!!!
- rt-thread i2c 使用教程