java---迭代器的应用

Iterator的对象问题
由集合调用iterator()方法返回一个Iterator对象
ArrayList list=new ArrayList();
Iterator itr=list.iterator();

package 迭代器遍历ArrayList;
import java.util.*;
public class Demo {
	public static void main(String []args)
	{
		ArrayList list = new ArrayList();
		for(int i=0;i<10;i++)
		{
			list.add(i);
		}
		Iterator itr = list.iterator();
		while(itr.hasNext())		//迭代器相当于指针
		{
			System.out.println(itr.next());
		}
	}
}

迭代器的删除操作

package ex7_38;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
//两个迭代器同时修改同一个集合会发生冲突,只能用当前的一个迭代器来修改
public class TwoIterator {

	public static void main(String[] args) {
		List list = new ArrayList();
		list.add("one");
		list.add("second");
		list.add("third");
		list.add(new Integer(4));
		list.add(new Float(5.0F));
		list.add("second"); // true
		list.add(new Integer(4)); // true
		ListIterator listIterator = list.listIterator();
		Iterator iterator = null;
		iterator = list.iterator();

		if (iterator.hasNext())
			iterator.next();
		iterator.remove();// 会删除该next()返回的元素。
		
		// 用另个迭代器操作上一个迭代器改变后的数据,将发生异常
		while (listIterator.hasNext())
			System.out.println(listIterator.next());

	}

}

Iterator和ListIterator的区别
1.ListIterator 有add方法,并且可以逆序遍历,修改对象,set方法对list等结构进行操作,而Iterator不可以,只能进行删除操作.

前序遍历:hasNext()//确定下一个元素存不存在
next()//指向下一个元素,并返回它

逆序遍历:hasPrevious()//确定最后一个元素存不存在
previous()//指向下一个元素,返回它

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
内容简介: 设计模式是一套被反复使用、多数人知晓的、经过分类编目的、代码设计经验的总结。使用设计模式是为了可重用代码、让代码更容易被他人理解、保证代码可靠性、程序的重用性。 本课程内容定位学习设计原则,学习设计模式的基础。在实际开发过程中,并不是一定要求所有代码都遵循设计原则,我们要考虑人力、时间、成本、质量,不是刻意追求完美,要在适当的场景遵循设计原则,体现的是一种平衡取舍,帮助我们设计出更加优雅的代码结构。本章将详细介绍开闭原则(OCP)、依赖倒置原则(DIP)、单一职责原则(SRP)、接口隔离原则(ISP)、迪米特法则(LoD)、里氏替换原则(LSP)、合成复用原则(CARP)的具体内容。 为什么需要学习这门课程? 你在日常的开发中,会不会也遇到过同样的问题。系统出现问题,不知道问题究竟出在什么位置;当遇到产品需求,总是对代码缝缝补补,不能很快的去解决。而且平时工作中,总喜欢把代码堆在一起,出现问题时,不知道如何下手,工作效率很低,而且自己的能力也得不到提升。而这些都源于一个问题,那就是软件设计没做好。这门课能帮助你很好的认识设计模式,让你的能力得到提升。课程大纲: 为了让大家快速系统了解设计模式知识全貌,我为您总结了思维导图,帮您梳理学习重点,建议收藏!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值