一文了解Java中 Vector、ArrayList、LinkedList 之间的区别

目录

[1. 数据结构](#1. 数据结构)

[Vector 和 ArrayList](#Vector 和 ArrayList)

LinkedList

[2. 线程安全](#2. 线程安全)

Vector

[ArrayList 和 LinkedList](#ArrayList 和 LinkedList)

[3. 性能](#3. 性能)

插入和删除操作

随机访问

[4. 内存使用](#4. 内存使用)

[ArrayList 和 Vector](#ArrayList 和 Vector)

LinkedList

[5. 迭代器行为](#5. 迭代器行为)

[ArrayList 和 Vector](#ArrayList 和 Vector)

LinkedList

[6. 扩展策略](#6. 扩展策略)

ArrayList

Vector

[7. 典型用例](#7. 典型用例)

ArrayList

LinkedList

Vector

[8. 总结](#8. 总结)


为了更加深入详细地介绍 Java 的 VectorArrayListLinkedList 的区别,我们将从以下几个方面进行探讨:数据结构、线程安全、性能、内存使用、迭代器行为、扩展策略和典型用例。

1. 数据结构

Vector 和 ArrayList

VectorArrayList 都是基于动态数组的数据结构。当需要更多空间时,它们会创建一个更大的数组并将旧数组中的内容复制到新数组中。

LinkedList

LinkedList 是基于双向链表的数据结构。每个元素(节点)都包含对前一个和后一个节点的引用。

2. 线程安全

Vector

Vector 是线程安全的,因为它的所有方法都使用了 synchronized 关键字。这确保了多个线程在访问 Vector 时不会发生数据不一致的情况。

ArrayList 和 LinkedList

ArrayListLinkedList 不是线程安全的。它们的方法没有使用 synchronized 关键字。在多线程环境中使用时,需要手动同步。

代码示例:手动同步 ArrayList

java 复制代码
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

public class SynchronizedArrayListExample {
    public static void main(String[] args) {
        List<String> synchronizedList = Collections.synchronizedList(new ArrayList<>());

        synchronizedList.add("A");
        synchronizedList.add("B");
        synchronizedList.add("C");

        synchronized (synchronizedList) {
            for (String element : synchronizedList) {
                System.out.println(element);
            }
        }
    }
}

3. 性能

插入和删除操作
  • ArrayList:插入和删除操作(尤其是中间位置)可能涉及移动大量元素,效率较低。
  • LinkedList:插入和删除操作效率高,因为只需修改前后节点的引用。
随机访问
  • ArrayList:基于数组,支持快速的随机访问(O(1))。
  • LinkedList:需要遍历链表,随机访问性能较差(O(n))。

4. 内存使用

ArrayList 和 Vector

因为它们使用的是数组,所以除了存储实际元素外,没有额外的开销。

LinkedList

每个节点除了存储元素外,还需要存储两个引用(前一个和后一个节点),因此内存开销较大。

5. 迭代器行为

ArrayList 和 Vector

由于它们是基于数组的结构,所以迭代器在迭代过程中能直接访问数组中的元素。

LinkedList

迭代器需要遍历链表,从一个节点移动到下一个节点。

6. 扩展策略

ArrayList

默认情况下,ArrayList 的扩展策略是增加原来容量的50%。

代码示例:ArrayList 扩展

java 复制代码
import java.util.ArrayList;

public class ArrayListResizeExample {
    public static void main(String[] args) {
        ArrayList<Integer> arrayList = new ArrayList<>(2);

        arrayList.add(1);
        arrayList.add(2);
        
        // 第一次扩展
        arrayList.add(3);

        System.out.println("ArrayList size: " + arrayList.size());  
        // Output: ArrayList size: 3
    }
}
Vector

默认情况下,Vector 的扩展策略是增加原来容量的100%。

代码示例:Vector 扩展

java 复制代码
import java.util.Vector;

public class VectorResizeExample {
    public static void main(String[] args) {
        Vector<Integer> vector = new Vector<>(2);

        vector.add(1);
        vector.add(2);

        // 第一次扩展
        vector.add(3);

        System.out.println("Vector size: " + vector.size());  
        // Output: Vector size: 3
    }
}

7. 典型用例

ArrayList

适用于需要频繁随机访问元素的场景,如:

  • 存储和访问大量元素
  • 按索引访问元素
LinkedList

适用于需要频繁插入和删除元素的场景,如:

  • 实现队列或栈
  • 频繁的插入和删除操作
Vector

适用于需要线程安全的动态数组场景,如:

  • 多线程环境下的动态数组操作

8. 总结

特性 Vector ArrayList LinkedList
数据结构 动态数组 动态数组 双向链表
线程安全性
插入/删除性能 慢(需要移动元素) 慢(需要移动元素) 快(只需修改引用)
随机访问性能 快(O(1)) 快(O(1)) 慢(O(n))
内存使用 较低 较低 较高
扩展策略 原容量的100% 原容量的50% N/A
典型用例 线程安全的动态数组操作 频繁随机访问元素 频繁插入和删除元素
相关推荐
金銀銅鐵6 分钟前
[Java] 以 IntStream 为例,浅析 Stream 的实现
java·后端
William一直在路上16 分钟前
Python数据类型转换详解:从基础到实践
开发语言·python
看到我,请让我去学习1 小时前
Qt— 布局综合项目(Splitter,Stacked,Dock)
开发语言·qt
GUET_一路向前1 小时前
【C语言防御性编程】if条件常量在前,变量在后
c语言·开发语言·if-else·防御性编程
曳渔1 小时前
UDP/TCP套接字编程简单实战指南
java·开发语言·网络·网络协议·tcp/ip·udp
三千道应用题1 小时前
WPF&C#超市管理系统(6)订单详情、顾客注册、商品销售排行查询和库存提示、LiveChat报表
开发语言·c#·wpf
hqxstudying2 小时前
JAVA项目中邮件发送功能
java·开发语言·python·邮件
咪咪渝粮2 小时前
JavaScript 中constructor 属性的指向异常问题
开发语言·javascript
最初的↘那颗心2 小时前
Java HashMap深度解析:原理、实现与最佳实践
java·开发语言·面试·hashmap·八股文
小兔兔吃萝卜2 小时前
Spring 创建 Bean 的 8 种主要方式
java·后端·spring