【JavaSE】十、ArrayList && LinkedList

文章目录

  • [Ⅰ. ArrayList](#Ⅰ. ArrayList)
  • [Ⅱ. LinkedList](#Ⅱ. LinkedList)
  • [ArrayList 与 LinkedList 的区别](#ArrayList 与 LinkedList 的区别)

Ⅰ. ArrayList

官方文档

构造函数有以下泛型参数:(其它有该构造函数的集合类均可这样子处理)

注意事项:

  1. 长度方法的区别:
    1. 数组用 .length 获取元素长度
    2. String.length() 获取元素长度
    3. 集合类用 .size() 获取元素长度
  2. ArrayList 不是线程安全的 ,在单线程下可以使用,在多线程中可以选择 CopyOnWriteArrayList
  3. ArrayList 底层是一段连续的空间,并且可以动态扩容,是一个动态类型的顺序表

注意事项:

  1. subList() 中拿到的 List 对象是原来 List 对象中的一部分,对这部分进行修改,是会影响到原对象的!
  2. 要使用迭代器,必须要实现 Iterator 接口,并且重写 iterator 方法!
  3. 注意 List<Integer> tmp = null 表示 tmp 是没有引用任何对象 ,而 List<Integer> tmp = new ArrayList<>() 表示有引用对象,但只是一个空盒子
  4. List.copyOf() 方法返回的 List 是不可变的!
  5. 下图是两个拷贝函数的区别:

遍历

java 复制代码
public static void main(String[] args) {
    List<Integer> list = new ArrayList<Integer>();
    list.add(10);
    list.add(20);
    list.add(30);
    list.add(40);
    list.add(50);

    // 1. 下标遍历(推荐⭐)
    for(int i = 0; i < list.size(); i++) {
        System.out.println(list.get(i));
    }

    // 2. for-each遍历(推荐⭐)
    for(Integer e: list) {
        System.out.println(e);
    }

    // 3. 迭代器遍历:使用Iterator的hasNext()和next()方法
    Iterator<Integer> iter = list.iterator();
    while(iter.hasNext()) {
        System.out.println(iter.next());
    }
}

Ⅱ. LinkedList

LinkedList 的底层是双向链表结构,由于链表没有将元素存储在连续的空间中,元素存储在单独的节点中,然后通过引用将节点连接起来了,因此在任意位置插入或者删除元素时,不需要搬移元素,效率比较高。

LinkedList 没有实现 RandomAccess 接口,因此 LinkedList 不支持随机访问

对于 LinkedList 来说,它的接口和 ArrayList 的接口基本是一样的,只是逻辑和物理存储上面的区别,所以具体接口可以参考 ArrayList 的笔记或者直接翻看官方文档!

遍历方式

go 复制代码
public static void main(String[] args) {
    List<Integer> list = new LinkedList<>();
    list.add(1);
    list.add(2);
    list.add(3);

    // 遍历方式一:使用自带的重写的toString()方法
    System.out.println(list);

    // 遍历方式二:for-each循环
    for (int e : list) {
        System.out.print(e + " ");
    }
    System.out.println();

    // 遍历方式三:普适的迭代器
    Iterator<Integer> it1 = list.iterator();
    while(it1.hasNext()) {
        System.out.print(it1.next() + " ");
    }
    System.out.println();

    // 遍历方式四:使用LinkedList专用的迭代器
    ListIterator<Integer> it2 = list.listIterator();
    while(it2.hasNext()) {
        System.out.print(it2.next() + " ");
    }
    System.out.println();

    // 遍历方式五:反向迭代器
    ListIterator<Integer> rit = list.listIterator(list.size());
    while(rit.hasPrevious()) {
        System.out.print(rit.previous() + " ");
    }
    System.out.println();
}

ArrayList 与 LinkedList 的区别

相关推荐
nanxun88619 小时前
记一次诡异的 Docker 容器"串包"故障排查
java
用户15630681035121 小时前
Day01 | Java 基础(Java SE)
java
行者全栈架构师1 天前
Maven dependency:tree 的 8 个高级用法
java·后端
行者全栈架构师1 天前
IDEA 中 Maven 项目的 15 个红色报错快速解决方法
java·后端
令人头秃的代码0_01 天前
mac(m5)平台编译openjdk
java
唐青枫2 天前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
一个做软件开发的牛马2 天前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户3721574261352 天前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java
用户3721574261352 天前
Java 打印 Word 文档:从基础打印到高级设置
java
用户3521802454753 天前
当 Prompt 学会"热更新":Spring Boot × Nacos3 AI 实战
java·spring boot·ai编程