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

相关推荐
JH30732 小时前
SpringBoot 优雅处理金额格式化:拦截器+自定义注解方案
java·spring boot·spring
Coder_Boy_3 小时前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
invicinble4 小时前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat
较真的菜鸟4 小时前
使用ASM和agent监控属性变化
java
黎雁·泠崖4 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
qq_12498707535 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
Coder_Boy_5 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Mr_sun.5 小时前
Day06——权限认证-项目集成
java
瑶山5 小时前
Spring Cloud微服务搭建四、集成RocketMQ消息队列
java·spring cloud·微服务·rocketmq·dashboard
abluckyboy5 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法