你真的明白关于迭代器的方法、使用异常、并发修改异常介绍嘛?

简介: 关于迭代器的方法、使用异常、并发修改异常介绍的使用

一、什么是迭代器?

          * JDK中提供了一个"Iterator接口",称为迭代器,可以"实现单列集合元素的遍历"

          * Collection接口中提供了iterator()方法,可以获取迭代器对象

//只能是单列集合使用,Map里面的双列集合是不可以的      

二、迭代器的方法

        * public boolean hasNext() : 判断是否存在下一个元素
        
        * public E next() :   获取下一个元素        (next()方法"获取元素",并且"指针移动"到下一个位置)
        
        * public void remove() : 删除元素
        
------------------------------------------------------------------------------------------------------------
            
            
//    迭代器使用步骤 :  (所有的单列集合都可以使用,因为迭代器是在Collection基础下的)

     1. 获取迭代器的对象                集合.iterator();
     2. 循环中,判断是否有元素可以获取     hasNext();
     3. 进入循环,调用next去获取元素      next();


代码演示:

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


        set.add("张三");
        set.add("李四");
        set.add("王五");
        set.add("张三");


        //获取迭代器的对象
        Iterator<String> itr = set.iterator();


        //hasNext():判断集合是否存在下一个元素,有返回true
        while (itr.hasNext()){

            String name = itr.next();            //获取集合的对象
            System.out.println(name);

        }

在这里插入图片描述


三、使用迭代器常见的异常

1、NoSuchElementException异常1

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


        set.add("张三");
        set.add("李四");
        set.add("王五");
        set.add("张三");


        //获取迭代器的对象
        Iterator<String> itr = set.iterator();


        //获取集合的对象
        System.out.println(itr.next());
        System.out.println(itr.next());
        System.out.println(itr.next());

        System.out.println(itr.next());  
//NoSuchElementException ,如果超过集合的长度取的话就会报没有这个数据的异常


//解决办法: 使用hasNext()判断取元素

在这里插入图片描述


2、NoSuchElementException异常2

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


        set.add("张三");
        set.add("李四");
        set.add("王五");
        set.add("张三");


        //获取迭代器的对象
        Iterator<String> itr = set.iterator();


        //hasNext():判断集合是否存在下一个元素,有返回true
        while (itr.hasNext()) {
        
        //不要在一次循环中,多次调用next方法
        //这里代表的是一次循环获取两个数据,如果是偶数的话就没有问题,如果是奇数的话就会报异常,获取不到,不建议
            System.out.println(itr.next());
            System.out.println(itr.next());

     }  

在这里插入图片描述


3、NoSuchElementException异常3

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

        set.add("张三");
        set.add("李四");
        set.add("王五");
        set.add("张三");


        //获取迭代器的对象
        Iterator<String> itr = set.iterator();


        while (itr.hasNext()) {

            System.out.println(itr.next());

        }

   

// 使用迭代器时候,数据不能重复使用
        System.out.println(itr.next());

 //NoSuchElementException ,因为这个迭代器里面的数据已经用完了,
//不能再使用这个迭代器获取数据,想使用的话要用新的迭代器

-----------------------------------------------------------------------------------------------------------
    
//解决办法 : 再次获取一个新的迭代器
    
        Iterator<String> itr2 = set.iterator();
        while (itr2.hasNext()){
            String next = itr2.next();
            System.out.println(next);
        }


在这里插入图片描述


4、无限循环

        Iterator<String> itr2 = set.iterator();
        while (itr2.hasNext()){
            String next = itr2.next();
            System.out.println(next);
        }


//一直问有没有数据,不做操作会进入死循环
        while(itr2.hasNext()){

        }

四、并发修改异常

1、产生原因

            当使用迭代器或者增强for循环遍历集合时,
                
            在迭代过程中调用集合类自身的remove或者add等方法改变集合的元素个数时,
                
            就会产生"ConcurrentModificationException",即"并发修改异常"
                
                "(两个对象同时在执行操作,造成冲突)"

        ArrayList<Integer> list=new ArrayList<>();
        
        list.add(11);
        list.add(22);
        list.add(33);
        list.add(44);
        list.add(55);

        Iterator<Integer> it1 = list.iterator();

//        迭代器在遍历集合,集合对象在删除数据,造成对数据处理的冲突
        while (it1.hasNext()){
            Integer number = it1.next();
            if(number%2==0){
                list.remove(number);
            }
        }

        System.out.println(list);   //ConcurrentModificationException : 并发修改异常
                                    // 两个对象同时在执行操作,造成冲突

在这里插入图片描述


2、解决办法

     1.使用普通for循环遍历元素,在循环中"使用集合自带的add或remove方法增删元素即可"
         
     2.如果使用迭代器遍历集合,在迭代过程中如果需要删除元素,可以"使用迭代器自带的remove方法"

     ArrayList<Integer> list=new ArrayList<>();
        
        list.add(11);
        list.add(22);
        list.add(33);
        list.add(44);
        list.add(55);

        Iterator<Integer> it1 = list.iterator();

        //解决办法:统一成一个对象就行
        while (it1.hasNext()){
            Integer number = it1.next();
            if(number%2==0){
               it1.remove();
            }
        }



        //也可以集合自己遍历删
        for (int i = 0; i < list.size(); i++) {
            Integer number = list.get(i);
            if(number%2==0){
                list.remove(number);
                i--;
            }
        }
    }
}

在这里插入图片描述


作者:KJ.JK

本文仅用于交流学习,未经作者允许,禁止转载,更勿做其他用途,违者必究。
文章对你有所帮助的话,欢迎给个赞或者 star,你的支持是对作者最大的鼓励,不足之处可以在评论区多多指正,交流学习

目录
相关文章
|
7月前
并发修改异常ConcurrentModificationException详解(一)
并发修改异常ConcurrentModificationException详解
134 0
并发修改异常ConcurrentModificationException详解(一)
|
7月前
并发修改异常ConcurrentModificationException详解(二)
并发修改异常ConcurrentModificationException详解
91 0
并发修改异常ConcurrentModificationException详解(二)
|
存储 Go
当map在不提前分配内存的时候为什么会抛异常?
当map在不提前分配内存的时候为什么会抛异常?
集合线程安全问题:第一章:集合类不安全之并发修改异常
集合线程安全问题:第一章:集合类不安全之并发修改异常
132 0
集合线程安全问题:第一章:集合类不安全之并发修改异常
|
缓存 Java 数据库
如何避免无意间创建多余对象
6 避免创建不必要的对象 从字面意思上来看,大家肯定都知道创建不必要的对象是错误的做法。但这一节其实主要是提醒我们避免无意识的创建不必要对象的代码写法。
如何避免无意间创建多余对象
|
存储 安全 Java
三种骚操作绕过迭代器遍历时的数据修改异常
三种骚操作绕过迭代器遍历时的数据修改异常
209 0
三种骚操作绕过迭代器遍历时的数据修改异常
|
开发者 Python
异常对象|学习笔记
快速学习 异常对象
132 0
|
算法 Java
JVM 怎么判断对象已经死了?
在Java中程序计数器、虚拟机栈、本地方法栈这三个区域随线程而生,随线程而灭:栈中的栈帧随着方法的调用和退出而有条不紊的进行着入栈和出栈的过程。
105 0
如何实现不论是否发生异常都必须执行 使用关键字finally finally: 我们有一些场景 需要保证代码无论是否异常都要执行 需要放到finally里
如何实现不论是否发生异常都必须执行 使用关键字finally finally: 我们有一些场景 需要保证代码无论是否异常都要执行 需要放到finally里