Iterator(迭代器) 和 list

Iterator(迭代器) 和 list

文章目录


提示:以下是本篇文章正文内容,下面案例可供参考

一、Iterator(迭代器)

对 collection 进行迭代的迭代器。迭代器取代了 Java Collections Framework 中的 Enumeration。

其中Iterator中有三个方法,分别为:

  • hasNext() : 如果仍有元素可以迭代,则返回 true
  • next() : 返回迭代 的下一个元素。
  • remove() :从迭代器指向的 collection 中移除迭代器返回的最后一个元素(可选操作)。
java 复制代码
        Collection<Integer> ct = new ArrayList<>();
        ct.add(12);
        ct.add(16);
        ct.add(56);
        ct.add(63);
        ct.add(96);
        ct.add(33);
        ct.add(69);

        Iterator<Integer> iter = ct.iterator();

        while (iter.hasNext()){
            int e = iter.next();
            System.out.println(e);
        }

		System.out.println(iter.hasNext());

		iter.remove();
        System.out.println(ct);

输出信息:

D:\kaifamiao\environments\OpenJDK-17.0.2\bin\java.exe -javaagent:D:\kaifamiao\applications\ideaIU-2021.2.2\ideaIU-2021.2.2\lib\idea_rt.jar=55736:D:\kaifamiao\applications\ideaIU-2021.2.2\ideaIU-2021.2.2\bin -Dfile.encoding=UTF-8 -classpath D:\kaifamiao\mycodes\java-base\out\production\iterator IteratorTest

12

16

56

63

96

33

69

false

12, 16, 56, 63, 96, 33

Process finished with exit code 0

而每一个迭代器只能从头到尾迭代一次,不然会报:

二、list

可以人为的指定顺序(定义顺序),可以重复(可以排序)(即有索引)。

其中一个实现此接口的类是 ArrayList<E>

包含两种增加方式:

  • add(E e) :将指定的元素添加到此列表的尾部。
  • add(int index, E element) :将指定的元素插入此列表中的指定位置。
java 复制代码
        List<Integer> list = new ArrayList<>();

        list.add(16);
        list.add(15);
        list.add(35);
        list.add(52);
        list.add(32);

        System.out.println(list);

        list.add( 1 , 56);
		System.out.println(list);

16, 15, 35, 52, 32

16, 56, 15, 35, 52, 32

Process finished with exit code 0

可以将属猪转化为 list集合 ,但对转化过来的 list集合 不能进行添加和删除元素 ,但可以对其进行 排序 和 替换。

java 复制代码
        Integer[] array = { 9, 10, 2, 6, 7, 3, 4 };
  
        List<Integer> list = Arrays.asList( array );
        System.out.println( list );

        List<Integer> numbers = new ArrayList<>();
        numbers.addAll( list );
        numbers.add( 1 );
        numbers.add( 0 , 5 );

        System.out.println( numbers );

而排序有两种方式,自然排序 和 比较器排序。其中 sort( null )是指没有在里面传任何比较器,所以为自然排序。

java 复制代码
        Comparator<Integer> comparator = new Comparator<Integer>() {
            @Override
            public int compare(Integer a, Integer b) {
                if( a != null && b != null ) {
                    return -( a - b );
                }
                return 0;
            }
        };

Java 8 之前,可以通过 Arrays.asList() 将数组 "转化"(造) 为 list 集合,但这个 list集合 不能添加,删除,但可以替换和排序。因为该类是 Arrays 中的内部类,所有外界不可对此进行添加删除。

而在 Java 8 之后,利用 list.of() 得到一个元素不能为 null(主要取决于实现类)且不可变的(即 添加删除排列,查找都不能)的 list 集合,并且 括号中第一个参数确定了之后参数的类型 (如果你参数列表中有多种类型,则会自动认定为 Object 类)。

copyOf() 复制过去的另一个集合也是不能进行修改的,他们的都是其内部类方法实现的。

其中 listIterator 是可以通过方法从第一个元素开始迭代,还是从索引 -1 的位置就开始迭代。

由此可以实现多次迭代。

ArrayList不是 线程安全 的。

快速失败 是指:

当检测出有迭代器时,应该使用迭代器所提供的方法,当发现使用(迭代器之外的)集合中的方法时,会尽可能的抛出异常。


相关推荐
sun03229 小时前
【架构基础】Spring中的PropertySourcesPlaceholderConfigurer介绍 (并非新知识,比较古老的一种使用方式)
java·spring·架构
chilavert3189 小时前
技术演进中的开发沉思-356:重排序(中)
java·开发语言
毕设源码-邱学长9 小时前
【开题答辩全过程】以 基于SSM的儿童福利院管理系统为例,包含答辩的问题和答案
java·eclipse
jianghua0019 小时前
Python中的简单爬虫
爬虫·python·信息可视化
devmoon9 小时前
为 Pallet 搭建最小化 Mock Runtime 并编写单元测试环境
开发语言·单元测试·区块链·智能合约·polkadot
TT哇10 小时前
【实习】数字营销系统 银行经理端(interact_bank)前端 Vue 移动端页面的 UI 重构与优化
java·前端·vue.js·ui
喵手10 小时前
Python爬虫实战:针对Python官网,精准提取出每一个历史版本的版本号、发布日期以及对应的文档/详情页链接等信息,并最终清洗为标准化的CSV文件!
爬虫·python·爬虫实战·零基础python爬虫教学·python官方数据采集·采集历史版本版本号等信息·导出csv文件
Elieal10 小时前
SpringBoot 数据层开发与企业信息管理系统实战
java·spring boot·后端
识君啊10 小时前
MyBatis-Plus 逻辑删除导致唯一索引冲突的解决方案
java·spring boot·mybatis·mybatis-plus·唯一索引·逻辑删除
Coder_Boy_10 小时前
Java开发者破局指南:跳出内卷,借AI赋能,搭建系统化知识体系
java·开发语言·人工智能·spring boot·后端·spring