2021-07-04笔记——迭代器

Iterator迭代器

【介绍】

  • Collection接口继承了lterable接口,在该接口中包含一个名为iterator的抽象方法,所有实现了Collection接口的容器类对该方法做了具体实现

  • iterator方法会返回一个lterator接口类型的迭代器对象,在该对象中包含了三个方法用于实现对单例容器的迭代处理

  • Map接口没有继承Iterable接口,因此不能直接使用迭代器,但是通过set集合获取key之后,set集合可使用迭代器

  • 原本不同容器使用不同的迭代方法,比如基于数组的使用索引,比如基于双向链表的使用上下关联的节点,现在对不同容器可采用相同迭代———迭代器

  • 迭代器循环中不能添加元素,foreach循环中,也不能添加元素,底层也是迭代器(ConcurrentModificationException)

【方法】

  • boolean hasNext(); //判断游标当前位置是否有元素,如果有返回true,否则返回false

  • Object next(); //获取当前游标所在位置的元素,并将游标移动到下一个位置

  • void remove(); //删除游标当前位置的元素,在执行完next后该操作只能执行一次;

使用Iterator迭代List接口类型容器
//实例化容器
        List<String> list = new ArrayList<>();
        list.add("a");
        list.add("b");
        list.add("c");
        //获取元素——获取迭代器对象
        Iterator<String> iterator = list.iterator();
        //方式一:在迭代器中,通过while循环获取元素
        while(iterator.hasNext()){
            String value = iterator.next();
            System.out.println(value);
        }
        //方法二:在迭代器中,通过for循环获取元素(先获取一个指定泛型的迭代器,否则会出现要求String和Object不相符的情况)
        for (Iterator<String> iterator1 = list.iterator();iterator1.hasNext();){
            String value = iterator1.next();
            System.out.println(value);
        }
使用Iterator迭代Set接口类型容器
//实例化Set容器
        Set<String> set = new HashSet<>();
        set.add("a");
        set.add("b");
        set.add("c");
        //方法一:先获取迭代器,通过while循环
        Iterator<String> iterator = set.iterator();
        while(iterator.hasNext()){
            String value = iterator.next();
            System.out.println(value);
        }
        System.out.println("---------------------");
        //方法二:通过for循环,循环条件内先获取迭代器
        for (Iterator<String> iterator1 = set.iterator(); iterator1.hasNext();){
            String value = iterator1.next();
            System.out.println(value);
        }
在迭代器中删除元素
List<String> list = new ArrayList<>();
        list.add("a");
        list.add("b");
        list.add("c");
        list.add("d");

        /*
        不要使用for循环在数组中按索引删除元素!!!
        为什么索引2和3的元素都被删除了?
        数组的特性,索引2的元素删除后,索引3的元素移动至索引2的位置,所以只要是索引2的元素删除,后面元素也依次删除
        每次循环list.size()会变化!!!
        在for循环内部再加一个条件判断即可
         */

        /*
        比如,会无限添加元素,因为list容器的上限一直在增加
        for (int i = 0; i < list.size(); i++) {
            list.add("aa");
        }
         */

        /*
        假设修正法:把 i从数组中拿出来,避免元素删除后后续元素补位的影响
        先定义一个int flag = -1,在循环内使用equals对比找到索引i,再把i赋值给flag
        if(flag > -1){
            list.remove(flag)
        }
         */
        for (int i = 0; i < list.size(); i++) {
            //list.remove(2);错误的用法!
            if ("c".equals(list.get(i))){
                list.remove(i);
            }
            System.out.println(list.get(i));
        }

        /*
        foreach循环中,同样可以使用equals对比定位某个字符串,然后将其删除
         */
        for(String str:list){
            if("c".equals(str)){
                list.remove(str);
            }
        }
        
        for(String str:list){
            System.out.println(str);
        }
 List<String> list = new ArrayList<>();
        list.add("a");
        list.add("b");
        list.add("c");
        list.add("d");

        //获取迭代器
        Iterator<String> iterator = list.iterator();
        while(iterator.hasNext()){
            //迭代器中next()方法获取当前元素,并把指针/游标移动到下一个元素,所以在一次循环中只能调用一次next()方法
            String value = iterator.next();
            if ("c".equals(value)){
                iterator.remove();
            }
        }

        for (Iterator<String> itr = list.iterator();itr.hasNext();){
            String val = itr.next();
            System.out.println(val);
        }
Collections工具类

提供了对Set、List、Map进行排序、填充、查找元素的辅助方法。该类中所有的方法都为静态方法

【常用方法】

  • void sort(List) //对List容器内的元素排序,排序的规则是按照升序进行排序
  • void shuffle(List) //对List容器内的元素进行随机排列
  • void reverse(List) //对List容器内的元素进行逆续排列
  • void fill(List, Object) //用一个特定的对象重写整个List容器
  • int binarySearch(List, Object) //对于顺序的List容器,采用二分法查找特定对象
使用sort方法对List类型容器进行排序
 List<String> list = new ArrayList<>();
        list.add("c");
        list.add("b");
        list.add("d");
        list.add("a");

        /*
        使用Collections工具类中的sort方法
        排序前:c b d a
        排序后:a b c d
         */
        Collections.sort(list);
        for (String str:list){
            System.out.println(str);
        }
使用shuffle方法对List类型容器进行随机排序(洗牌)
List<String> list1 = new ArrayList<>();
        list1.add("a");
        list1.add("b");
        list1.add("c");
        list1.add("d");

        /*
        使用Collections工具类中的shuffle方法进行随机排序
        排序前:a b c d
        排序后的某一次:a c d b
         */
        Collections.shuffle(list1);
        for (String str:list1){
            System.out.println(str);
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值