List集合逆向遍历,迭代器Iterator&ListIterator的区别,希望能帮助到你.

概述:

       在使用java集合的时候,大家都知道都需要使用Iterator,但是java集合中还有一个迭代器ListIterator,在使用List、ArrayList、LinkedList和Vector的时候可以使用。这两种迭代器有什么区别呢?

下面我们详细分析。这里有一点需要明确的时候,迭代器指向的位置是元素之前的位置,如下图所示:

 

       这里假设集合List由四个元素List1、List2、List3和List4组成,当使用语句Iterator it = List.Iterator()时,迭代器it指向的位置是上图中Iterator1指向的位置,当执行语句it.next()之后,迭代器指向的位置后移到上图Iterator2所指向的位置。


包含的方法:

说明:首先看一下IteratorListIterator迭代器的方法有哪些。

 

Iterator迭代器包含的方法有:

  • hasNext():如果迭代器指向位置后面还有元素,则返回 true,否则返回false
  • next():返回集合中Iterator指向位置后面的元素
  • remove():删除集合中Iterator指向位置后面的元素
public class iteratorTest {

	          public static void main(String[] args) {
				
	        	ArrayList list = new ArrayList();
	        	list.add("hhh");
	        	list.add("aaa");
	        	list.add("ccc");
	               
	           Iterator it = list.Iterator();
	           while(it.hasNext()){//判断,有元素的话返回true,没有元素返回false
	        	   Object value = it.next();//获取Iterator当前位置后面的元素
	        	   System.out.println(value);
	           }
			}

打印结果:
hhh
aaa
ccc
	

ListIterator迭代器包含的方法有:

  • add(E e): 将指定的元素插入列表,插入位置为迭代器当前位置之前
  • hasNext():以正向遍历列表时,如果列表迭代器后面还有元素,则返回 true,否则返回false
  • hasPrevious() : 如果以逆向遍历列表,列表迭代器前面还有元素,则返回 true,否则返回false
  • next():返回列表中ListIterator指向位置后面的元素
  • nextIndex() :返回列表中ListIterator所需位置后面元素的索引
  • previous() : 返回列表中ListIterator指向位置前面的元素
  • previousIndex():返回列表中ListIterator所需位置前面元素的索引
  • set(E e):从列表中将next()或previous()返回的最后一个元素返回的最后一个元素更改为指定元素e

相同点:

都是迭代器,当需要对集合中元素进行遍历不需要干涉其遍历过程时,这两种迭代器都可以使用。

不同点:

1).使用范围不同,Iterator可以应用于所有的集合,Set、List和Map和这些集合的子类型。而ListIterator只能用于List及其子类型

2).ListIterator有add方法,可以向List中添加对象,而Iterator不能。

3).istIterator和Iterator都有hasNext()和next()方法,可以实现顺序向后遍历,但是ListIterator有hasPrevious()和previous()方法,可以实现逆向(顺序向前)遍历。Iterator不可以。

4).ListIterator可以定位当前索引的位置nextIndex()previousIndex()可以实现。Iterator没有此功能。

5).都可实现删除操作,但是ListIterator可以实现对象的修改set()方法可以实现。Iterator仅能遍历,不能修改。


案例:

public class iteratorTest {

	/**
	 * @ClassName: IteratorTest1
	 * @Description: 反向遍历list集合
	 */  
	    public static void main(String[] args) {
	        
	        List<Integer> list = new ArrayList<Integer>();
	   
	        for(int i=0;i<10;i++){
	        	list.add(i);
	        }
	        //1.正向遍历
	        //1.1获取迭代器
	     ListIterator<Integer> lt = list.listIterator();
	     System.out.println("list集合正向遍历:");
	        while(lt.hasNext()){//1.2判断当前指向的位置后有没有元素
	        	Integer n= lt.next();//1.3如果有获取当前指向位置的元素
	        	System.out.print(n);
	        }
	     System.out.println(""); 
	     System.out.println("list集合反向遍历:");     
	        //2.反向遍历
	        //2.1 将游标定位到集合的结尾
	        while(lt.hasNext()){
	        	lt.next();
	        }
	       //使用反向遍历的方法
	        while(lt.hasPrevious()){//2.2这时游标已定位到集合结尾处,判断游标位置前面是否有元素
	       Integer	m=lt.previous();//2.3如果有元素,就获取到前面的元素
	        System.out.print(m);	
	        }
	}


输出结果:

list集合正向遍历:
0123456789
list集合反向遍历:
9876543210

谢谢您的阅读,希望对您有所帮助!              

 

 

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值