Java各种List实现类以及特点

devtools/2024/10/18 14:26:41/

目录

1. ArrayList

2. LinkedList

3. Vector

4. Stack

5. CopyOnWriteArrayList


1. ArrayList

  • 特性:
    • 基于动态数组实现。
    • 提供快速的随机访问能力。
    • 在列表末尾添加/删除元素非常快,但在列表中间插入/删除元素可能需要移动元素,较慢。
    • 每次自动增长时,数组大小增加50%。

2. LinkedList

  • 特性:
    • 基于双向链表实现。
    • 优于ArrayList在列表中间的插入和删除操作。
    • 提供了额外的方法和接口,如Deque,可以作为队列、双端队列或栈使用。
    • 随机访问速度慢,因为需要从头或尾部遍历链表。

3. Vector

  • 特性:
    • 类似于ArrayList,但所有方法都是同步的,是线程安全的。
    • 因为线程同步,通常比ArrayList慢。
    • 每次自动增长时,数组大小增加一倍,或者增加指定的大小。

4. Stack

  • 特性:
    • 继承自Vector,实现了一个后进先出(LIFO)的堆栈。
    • 提供了基本的堆栈操作:push、pop、peek等。
    • 由于是Vector的子类,因此它也是线程安全的。
    • Java官方推荐使用Deque接口和其实现(如ArrayDeque)来创建和操作堆栈。

5. CopyOnWriteArrayList

  • 特性:
    • 线程安全的List实现,基于最终一致性的原理。
    • 在写操作时,如add、set、remove,会复制整个底层数组。
    • 适用于读多写少的并发场景。
    • 迭代器不支持修改操作,如remove、set和add。

总结

  Java中的List接口有多种实现,每种实现都有其特定的特性和用途。ArrayList和Vector提供了基于数组的列表,其中Vector是线程安全的。LinkedList提供了基于链表的操作,适合频繁的插入和删除操作。Stack是Vector的一个子类,提供了堆栈的操作,但现在通常推荐使用Deque接口的实现。CopyOnWriteArrayList是一种线程安全的List实现,适用于读多写少的并发场景。根据应用程序的需求,比如对线程安全、随机访问速度、插入和删除操作的性能等因素,可以选择合适的List实现。


http://www.ppmy.cn/devtools/28576.html

相关文章

【Linux系统编程】31.pthread_detach、线程属性

目录 pthread_detach 参数pthread 返回值 测试代码1 测试结果 pthread_attr_init 参数attr 返回值 pthread_attr_destroy 参数attr 返回值 pthread_attr_setdetachstate 参数attr 参数detachstate 返回值 测试代码2 测试结果 线程使用注意事项 pthread_deta…

万兴PDF专家 PDFelement Pro v10.3.8 破姐版!

🧑‍💻万兴PDF专家 PDFelement Pro v10.3.8 破姐版 (https://docs.qq.com/sheet/DRVVxTHJ3RXJFVHVr)

FreeBSD下安装Linux兼容系统Ubuntu

FreeBSD有个很神奇的功能,就是跟Linux二进制兼容,也就是可以直接运行linux的bin文件。还有个更神奇的功能,就是能运行出一套Linux系统,完全是linux的用户,linux的目录系统,而且还可以选是Centos系统还是Ubu…

TCP案例之单聊与群聊

TCP案例之单聊与群聊 一、TCP案例之单聊 在基于TCP协议的单聊应用中,通常涉及客户端和服务器端的交互。 服务器端 建立服务器: 服务器端创建一个TCP Socket并绑定到一个特定的端口,开始监听来自客户端的连接请求。 接受连接: …

kafka 线上消费积压问题

背景 线上kafka 流量大,消费小于生产,如何处理? 方案 增加consumer数量 可以增加consumer的消费者,不过这个只能在一定程序上缓解,如果consumer 数量超过partition 数,那有的就会空转,解决不…

速盾:高防cdn-为您的网站防御cc/ddos

随着互联网的飞速发展,网站安全问题也日益突出。网站被黑客攻击的事件频频发生,给用户和网站运营商带来了巨大的损失。其中,CC攻击和DDoS攻击是最常见的攻击手段之一。为了有效应对这些攻击,提高网站的安全性,高防CDN成…

算法训练营day25

零、回溯算法理论 参考链接13.1 回溯算法 - Hello 算法 (hello-algo.com) 1.尝试与回退 之所以称之为回溯算法,是因为该算法在搜索解空间时会采用“尝试”与“回退”的策略。当算法在搜索过程中遇到某个状态无法继续前进或无法得到满足条件的解时,它会…

vue集成百度地图vue-baidu-map

文章目录 vue集成百度地图vue-baidu-map1. Vue Baidu Map文档地址2. 设置npm数据源3. 安装vue-baidu-map4. 配置vue-baidu-map4.1 main.js全局注册4.2 vue页面设置4.3 效果 vue集成百度地图vue-baidu-map 1. Vue Baidu Map文档地址 https://dafrok.github.io/vue-baidu-map/#…