6个回答
2013-07-20
展开全部
我们在使用List,Set的时候,为了实现对其数据的遍历,我们经常使用到了Iterator(跌代器)。 使用跌代器,你不需要干涉其遍历的过程,只需要每次取出一个你想要的数据进行处理就可以了。但是在使用的时候也是有不同的。 List和Set都有iterator()来取得其迭代器。对List来说,你也可以通过listIterator()取得其迭代器,两种迭代器在有些时候是不能通用的,Iterator和ListIterator主要区别在以下方面: 1. ListIterator有add()方法,可以向List中添加对象,而Iterator不能 2. ListIterator和Iterator都有hasNext()和next()方法,可以实现顺序向后遍历,但是ListIterator有hasPrevious()和previous()方法,可以实现逆向(顺序向前)遍历。Iterator就不可以。 3. ListIterator可以定位当前的索引位置,nextIndex()和previousIndex()可以实现。Iterator没有此功能。 4. 都可实现删除对象,但是ListIterator可以实现对象的修改,set()方法可以实现。Iierator仅能遍历,不能修改。 因为ListIterator的这些功能,可以实现对LinkedList等List数据结构的操作。 其实,数组对象也可以用迭代器来实现。 org.apache.commons.collections.iterators.ArrayIterator就可以实现此功能。 一般情况下,我们使用Iterator就可以了,如果你需要进行记录的前后反复检索的话,你就可以使用ListIterator来扩展你的功能,(有点象JDBC中的滚动结果集)。 ListIterator是一个双向迭代器。ListIterator没有当前元素,它的当前游标是位于调用next()和previsous()返回的元素之间。
2013-07-20
展开全部
链表的一些方法使用和迭代器的使用(把链表内的元素迭代出),你可以看下~ import java.util.*;public class test11 {
static LinkedList list = new LinkedList();
String[] arrays = {"1","2","3","4","5"};
static Iterator it ;
public static void main(String[] args) {
test11 t = new test11();
t.useLinkedList(list);
t.useIterator(list,it);
}//链表的使用
public void useLinkedList(LinkedList list)
{
for(int i = 0;i < 5;i++)
list.add(arrays[i]);//把数组的元素都添加到链表
System.out.println("操作前的长度:"+list.size());//打印出链表的长度
System.out.println("此列表的头(第一个元素)为:"+list.peek());/*peek() 找到但不移除此列表的头(第一个元素)。*/
System.out.println("查找后的长度:"+list.size());
System.out.println("移除的元素为:"+list.poll()); /*poll() 找到并移除此列表的头(第一个元素)。*/
System.out.println("移除后的长度:"+list.size());
System.out.println("返回第一个元素:"+list.getFirst());//getFirst() 返回此列表的第一个元素。
System.out.println("返回最后一个元素:"+list.getLast());//getLast() 返回此列表的最后一个元素。
if(list.contains("4"))//boolean contains(Object o) 如果此列表包含指定元素,则返回 true。
System.out.println("存在此元素");
else
System.out.println("不存在此元素");
}//迭代器的使用
public void useIterator(LinkedList list,Iterator it)
{
it = list.iterator();
//将链表的元素迭代出并打印
while(it.hasNext())
System.out.print(it.next()+"\t");
}
}
static LinkedList list = new LinkedList();
String[] arrays = {"1","2","3","4","5"};
static Iterator it ;
public static void main(String[] args) {
test11 t = new test11();
t.useLinkedList(list);
t.useIterator(list,it);
}//链表的使用
public void useLinkedList(LinkedList list)
{
for(int i = 0;i < 5;i++)
list.add(arrays[i]);//把数组的元素都添加到链表
System.out.println("操作前的长度:"+list.size());//打印出链表的长度
System.out.println("此列表的头(第一个元素)为:"+list.peek());/*peek() 找到但不移除此列表的头(第一个元素)。*/
System.out.println("查找后的长度:"+list.size());
System.out.println("移除的元素为:"+list.poll()); /*poll() 找到并移除此列表的头(第一个元素)。*/
System.out.println("移除后的长度:"+list.size());
System.out.println("返回第一个元素:"+list.getFirst());//getFirst() 返回此列表的第一个元素。
System.out.println("返回最后一个元素:"+list.getLast());//getLast() 返回此列表的最后一个元素。
if(list.contains("4"))//boolean contains(Object o) 如果此列表包含指定元素,则返回 true。
System.out.println("存在此元素");
else
System.out.println("不存在此元素");
}//迭代器的使用
public void useIterator(LinkedList list,Iterator it)
{
it = list.iterator();
//将链表的元素迭代出并打印
while(it.hasNext())
System.out.print(it.next()+"\t");
}
}
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-07-20
展开全部
你应该知道迭代器首先是干什么用的,在集合框架中,有所讲解,我在这里就不重复了,其中迭代器,是为了,遍历集合中的所用元素,所提供的一种通用方法public static void print(Collection c){//产生一个通用的迭代器迭代器将Collection类型的集合作为参数传入 Itreator it = c.itreator(); while(it.hasNext){//判断是否有下一个元素 System.out.println(it,next());打印出元素}class Test{ public static void main(String[] args){ Vector ve = new Vector();//定义一个集合的引用类型 ve.add("张三"); ve.add("李四"); print(ve);//在这里调用通用的迭代器,将集合中的元素全部打印出来 /////////////////////////////////////////////////////////// 还可以直接写迭代器,上楼上的那样,写在主方法里就行} }}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-07-20
展开全部
比方说:List ls = new ArrayList();Iterator it = ls.iterator();while(it.hasNext()){MyPojo o = (MyPojo)it.next();}以上代码手打的,可能有字母错误
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
讲解的是Java增强,重点讲解的是享元模式,增强的for循环的本质就是迭代器,同时还讲解了迭代器遍历集合的方式。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询