【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 的区别

相关推荐
极客先躯15 分钟前
高级java每日一道面试题-2025年11月24日-容器与虚拟化题[Dockerj]-runc 的作用是什么?
java·oci 的命令行工具·最小可用·无守护进程·完全标准·创建容器的核心流程·runc 核心职责思维导图
用户606487671889620 分钟前
AI 抢不走的技能:用 Claude API 构建自动化工作流实战
java
我命由我1234532 分钟前
Kotlin 开发 - lateinit 关键字
android·java·开发语言·kotlin·android studio·android-studio·android runtime
aXin_ya33 分钟前
微服务第八天 Sentinel 四种分布式事务模式
java·数据库·微服务
Halo_tjn36 分钟前
Java Set集合相关知识点
java·开发语言·算法
Linsk42 分钟前
Java和JavaScript的关系真是雷峰和雷峰塔的关系吗?
java·javascript·oracle
许彰午1 小时前
我手写了一个 Java 内存数据库(二):B+ 树的插入与分裂
java·开发语言·面试
zhouwy1131 小时前
Java 快速入门笔记:从基础语法到 Spring Boot 实战
java
极创信息1 小时前
信创产品认证怎么做?信创产品测试认证的主要流程
java·大数据·数据库·金融·软件工程
SamDeepThinking2 小时前
并发量就算只有2,该上锁还得上呀
java·后端·架构