9.8-全栈Java笔记:Iterator(迭代器)接口

来源:互联网 发布:淘宝网如何提高流量 编辑:程序博客网 时间:2024/06/02 06:27

迭代器介绍

所有实现了Collection接口的容器类都有一个iterator方法用以返回一个实现了Iterator接口的对象。

Iterator对象称作迭代器,用以方便的实现对容器内元素的遍历操作。

Iterator接口定义了如下方法:

boolean hasNext();  //判断是否有元素没有被遍历

Object next();      //返回游标当前位置的元素并将游标移动到下一个位置

void remove(); //删除游标左面的元素,在执行完next之后该操作只能执行一次 


  1 Iterator接口的next()方法的执行原理

 使用Iterator迭代器遍历容器(List/Set/Map

迭代器为我们提供了统一的遍历容器的方式。

【示例1】迭代器遍历List

public class   Test {

    public static void   main(String[] args) {

       List<String> aList = new   ArrayList<String>();

       for (int i   = 0; i < 5; i++){

           aList.add("a" +   i);

       }

       System.out.println(aList);

       for(Iterator<String>   iter = aList.iterator();iter.hasNext();){

           String temp = iter.next();

           System.out.print(temp+"\t");

           if(temp.endsWith("3")){     //删除3结尾的字符串

              iter.remove();

           }

       }

       System.out.println();

       System.out.println(aList);

    }

}

老鸟建议:

如果遇到遍历容器时,判断删除元素的情况,使用迭代器遍历!

【示例2】迭代器遍历Set

public class   Test {

    public static void   main(String[] args) {

       Set<String> set = new   HashSet<String>();

       for (int i   = 0; i < 5; i++){

           set.add("a" +   i);

       }

       System.out.println(set);

       for(Iterator<String>   iter = set.iterator();iter.hasNext();){

           String temp = iter.next();

           System.out.print(temp+"\t");

       }

       System.out.println();

       System.out.println(set);

    }

}

【示例3】迭代器遍历Map

import   java.util.*;

import   java.util.Map.Entry;

 

public class   Test {

    public static void   main(String[] args) {

       Map<String,String> map = new   HashMap<String,String>();

       map.put("A""高淇");

       map.put("B""高小七");

       Set<Entry<String, String>>  ss = map.entrySet();

       for   (Iterator<Entry<String, String>> iterator = ss.iterator();   iterator.hasNext();) {

           Entry<String,String> e =  iterator.next();

           System.out.println(e.getKey()+"--"+e.getValue());  

       }

    }

}

 我们也可以通过mapkeySet()valueSet()获得keyvalue的集合,从而遍历它们。

public class Test   {

    public static void   main(String[] args) {

       Map<String,String> map = new   HashMap<String,String>();

       map.put("A""高淇");

       map.put("B""高小七");

      

       Set<String>  ss   = map.keySet();

       for   (Iterator<String> iterator = ss.iterator(); iterator.hasNext();) {

           String key =    iterator.next();

           System.out.println(key+"--"+map.get(key));  

       }

 

    }

}





「全栈Java笔记」是一部能帮大家从零到一成长为全栈Java工程师系列笔记。笔者江湖人称 Mr. G,10年Java研发经验,曾在神州数码、航天院某所研发中心从事软件设计及研发工作,从小白逐渐做到工程师、高级工程师、架构师。精通Java平台软件开发,精通JAVAEE,熟悉各种流行开发框架。


   笔记包含从浅入深的六大部分:

   A-Java入门阶段

   B-数据库从入门到精通

   C-手刃移动前端和Web前端

   D-J2EE从了解到实战

   E-Java高级框架精解

   F-Linux和Hadoop