当前位置: 首页 > 编程笔记 >

java中Iterator和ListIterator实例详解

孙恩
2023-03-14
本文向大家介绍java中Iterator和ListIterator实例详解,包括了java中Iterator和ListIterator实例详解的使用技巧和注意事项,需要的朋友参考一下

Iterator和ListIterator的作用范围以及关系:

(1) Iterator可以用于迭接口List的实现ArrayList,LinkedList以及Map等。
(2) ListIterator顾名思义,就是用于迭代List实现ArrayList,LinkedList。
(3) 从源码或API文档中可以看出,Iterator为ListIterator的父类。

public interface ListIterator<E> extends Iterator<E> {
	// 省略......
}

在ListIterator中增加了新方法。

迭代器隐式游标位置实例分析:

如上图,在迭代器要迭代的集合List中有四个元素a,b,c,d,当调用xxx.iterator()或xxx.listIterator()方法时,

迭代器指向Iterator_one的位置,当调用xxx.next()方法时,迭代器位置指向Iterator_two位置。

迭代器指向的位置并不是正对着元素,而是在元素之间。

Iterator和ListIterator中的方法:

------Iterator中的方法:

官方API方法概要:

方法分析:

hasNext():判断集合中元素迭代器所指下一个位置是否有元素,有返回true,否则返回false

next():返回迭代器所指向位置下一个元素值。

remove():删除迭代器通过iterator取出的值。

------ListIterator中的方法:

官方API方法概要:

方法分析:

add(Ee):在集合中插入指定元素,插入位置与最后一次操作next()或previous()方法有关。

如果最后操作的是next(),则在该next取出的元素之后插入元素,如果是previous()则在取出的元素之前插入元素。

hasNext():集合正序遍历时,判断隐式游标所指的下一个元素是否存在,存在返回true,否则返回false。

hasPrevious():集合反向遍历时,判断隐式游标的上一个元素是否存在,存在返回true,否则返回false。

next():返回隐式游标所指位置下一个元素值。

nextIndex():返回隐式游标所指位置下一个元素的索引值。

previous():返回隐式游标所指位置的上一个元素值。

previousIndex():返回隐式游标所指上一个位置元素的索引值。

remove():从集合中删除元素,并不是删除所有的元素,而是删除最后一次操作next()或previous()返回的元素,

如果next()或previous()没有返回值,则报错。

set(Ee):从列表中将next()或previous()返回的元素替换为e,比如,next()取出为a,可以通过set将a替换为one。

实例1:

package com.lanhuigu.java;
import java.util.ArrayList;
import java.util.List;
import java.util.ListIterator;
public class ListIteratorAPITest {
	public static void main(String[] args) {
		List<String> list = new ArrayList<String>();
		list.add("a");
		list.add("b");
		list.add("c");
		list.add("d");
		// 此时,迭代器指向Iterator_one位置 
		ListIterator<String> listIterator = list.listIterator();
		// 此时,迭代器指向Iterator_two位置 
		String firstElement = listIterator.next();
		// 删除元素 
		listIterator.remove();
		// 删除next取出的元素,此时已经将a从集合中删除 
		// 添加元素 
		//listIterator.previous(); 
		listIterator.add("e");
		// 在指向位置Iterator_two之前,即为之前a的位置 
		// 打印next取出的元素 
		System.out.println("firstElement:" + firstElement);
		// 将指向位置重新初始化到Iterator_one位置,但是a已经别删除,添加了e 
		listIterator = list.listIterator();
		while(listIterator.hasNext()) {
			System.out.println(listIterator.next());
		}
		System.out.println("--------------");
		// set 方法测试 
		listIterator = list.listIterator();
		// 将e替换为eeee 
		System.out.println("dddd"+listIterator.next());
		listIterator.set("eeee");
		System.out.println("---------------");
		// 将游标位置挪到首元素位置,打印元素,证明将e修改为eeee成功 
		listIterator = list.listIterator();
		while(listIterator.hasNext()) {
			System.out.println(listIterator.next());
		}
	}
}

实例二:

package com.lanhuigu.java;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
public class IteratorAPITest {
	public static void main(String[] args) {
		List<String> list = new ArrayList<String>();
		list.add("a");
		list.add("b");
		list.add("c");
		list.add("d");
		// 第一种遍历集合的方式,直接通过循环语句(for,do-while,while)遍历 
		// for 
		for (String e : list) {
			System.out.println(e);
		}
		System.out.println("------------");
		// 第二种遍历集合的方式(Iterator) 
		Iterator<String> iterator = list.iterator();
		while(iterator.hasNext()) {
			System.out.println(iterator.next());
		}
		System.out.println("------------");
		// 第三种遍历集合的方式(ListIterator) 
		ListIterator<String> listIterator = list.listIterator();
		while(listIterator.hasNext()) {
			System.out.println(listIterator.next());
		}
		System.out.println("------------");
	}
}

总结

以上就是本文关于java中Iterator和ListIterator实例详解的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

 类似资料:
  • 本文向大家介绍请你说说Iterator和ListIterator的区别?相关面试题,主要包含被问及请你说说Iterator和ListIterator的区别?时的应答技巧和注意事项,需要的朋友参考一下 考察点:迭代器 Iterator和ListIterator的区别是: Iterator可用来遍历Set和List集合,但是ListIterator只能用来遍历List。 Iterator对集合只能是前

  • 本文向大家介绍Java中Iterator和Spilled Iterator的区别。,包括了Java中Iterator和Spilled Iterator的区别。的使用技巧和注意事项,需要的朋友参考一下 迭代器和拆分迭代器这两个接口都用于迭代集合。 Java 8中引入了拆分迭代器来实现并行性。它可以拆分给定的元素集,并可以使用不同的独立线程并行执行操作。它可以并行地以及顺序地遍历元素。splitIte

  • 问题内容: 我试图了解Java 和接口 我正在写这堂课 它似乎正在工作。 我应该有: 或者我应该把外面的 哪一个更好? 问题答案: 你应该几乎 从来没有 同时实现,并在同一个班。他们做不同的事情。迭代器自然是 有状态的 -当您迭代使用它时,它必须更新其世界观。但是,迭代器仅需要能够创建新的迭代器。特别是,您可能有多个迭代器同时处理同一个原始可迭代对象。 您当前的方法几乎可以-我会更改实现的某些方面

  • 本文向大家介绍对Python中Iterator和Iterable的区别详解,包括了对Python中Iterator和Iterable的区别详解的使用技巧和注意事项,需要的朋友参考一下 Python中 list,truple,str,dict这些都可以被迭代,但他们并不是迭代器。为什么? 因为和迭代器相比有一个很大的不同,list/truple/map/dict这些数据的大小是确定的,也就是说有多少

  • 通常,您需要遍历集合中的元素。 例如,您可能希望显示每个元素。 最简单的方法是使用迭代器,它是一个实现Iterator或ListIterator接口的对象。 Iterator使您可以循环访问集合,获取或删除元素。 ListIterator扩展Iterator以允许列表的双向遍历和元素的修改。 在通过迭代器访问集合之前,必须先获取一个集合。 每个集合类都提供了一个iterator()方法,该方法将迭

  • 本文向大家介绍java中DelayQueue实例用法详解,包括了java中DelayQueue实例用法详解的使用技巧和注意事项,需要的朋友参考一下 在阻塞队里中,除了对元素进行增加和删除外,我们可以把元素的删除做一个延迟的处理,即使用DelayQueue的方法。这里的删除需要一定的时间才能生效,有点类似于过期处理的理念。下面我们就DelayQueue的概念、特点进行讲解,然后在代码示例中体会Del