java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > java中Iterator和ListIterator

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实例详解的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

您可能感兴趣的文章:
阅读全文