容器三(ArrayList、LinkedList、Vector)

目录

[ArrayList 特点和底层实现](#ArrayList 特点和底层实现)

[LinkedList 特点和底层实现](#LinkedList 特点和底层实现)

[Vector 向量](#Vector 向量)


ArrayList 特点和底层实现

ArrayList 底层是用数组实现的存储。 特点:查询效率高,增删效率低,线程不安全。 在 List 的多个实现类中,我们一般使用它来处理业务。查看源码:

我们可以看出 ArrayList 底层使用 Object 数组来存储元素数据。所有的方法,都围绕这个核心的 Object 数组来开展。

我们知道,数组长度是有限的,而 ArrayList 是可以存放任意数量的对象,长度不受限 制,那么它是怎么实现的呢?本质上就是通过定义新的更大的数组,将旧数组中的内容拷贝 到新数组,来实现扩容。 ArrayList 的 Object 数组初始化长度为 10,如果我们存储满了这个 数组,需要存储第 11 个对象,就会定义新的长度更大的数组,并将原数组内容和新的元素 一起加入到新数组中,源码如下:

java 复制代码
    /**
    * Default initial capacity.
    */
    private static final int DEFAULT_CAPACITY = 10;

    /**
     * Shared empty array instance used for default sized empty instances. We
     * distinguish this from EMPTY_ELEMENTDATA to know how much to inflate when
     * first element is added.
     */
    private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};

    public void ensureCapacity(int minCapacity) {
        int minExpand = (elementData != DEFAULTCAPACITY_EMPTY_ELEMENTDATA)
            // any size if not default element table
            ? 0
            // larger than default for default empty table. It's already
            // supposed to be at default size.
            : DEFAULT_CAPACITY;

        if (minCapacity > minExpand) {
            ensureExplicitCapacity(minCapacity);
        }
    }

    private void ensureExplicitCapacity(int minCapacity) {
        modCount++;

        // overflow-conscious code
        if (minCapacity - elementData.length > 0)
            grow(minCapacity);
    }

    /**
     * Increases the capacity to ensure that it can hold at least the
     * number of elements specified by the minimum capacity argument.
     *
     * @param minCapacity the desired minimum capacity
     */
    private void grow(int minCapacity) {
        // overflow-conscious code
        int oldCapacity = elementData.length;
        int newCapacity = oldCapacity + (oldCapacity >> 1);
        if (newCapacity - minCapacity < 0)
            newCapacity = minCapacity;
        if (newCapacity - MAX_ARRAY_SIZE > 0)
            newCapacity = hugeCapacity(minCapacity);
        // minCapacity is usually close to size, so this is a win:
        elementData = Arrays.copyOf(elementData, newCapacity);
    }

LinkedList 特点和底层实现

LinkedList 底层用双向链表实现的存储。特点:查询效率低,增删效率高,线程不安全。

双向链表也叫双链表,是链表的一种,它的每个数据节点中都有两个指针,分别指向前 一个节点和后一个节点。 所以,从双向链表中的任意一个节点开始,都可以很方便地找到 所有节点。

每个节点都应该有 3 部分内容:

java 复制代码
class Node {
    Node prev; //前一个节点
    Object item; //本节点保存的数据
    Node next; //后一个节点
}

查看 LinkedList 的源码,可以看到里面包含了双向链表的相关代码:

Vector 向量

Vector 底层是用数组实现的 List,相关的方法都加了同步检查,因此"线程安全,效率低"。 比如,indexOf 方法就增加了 synchronized 同步标记。

如何选用 ArrayList、LinkedList、Vector?

需要线程安全时,用 Vector。

不存在线程安全问题时,并且查找较多用 ArrayList(一般使用它)。

不存在线程安全问题时,增加或删除元素较多用 LinkedList。

相关推荐
永卿001几秒前
设计模式-责任链模式
java·设计模式·责任链模式
hello 早上好4 分钟前
深入解析AOP调用链:递归与责任链模式的协同实现
java·责任链模式
程序员编程指南7 分钟前
Qt 开发自动化测试框架搭建
c语言·开发语言·c++·qt
wangmengxxw14 分钟前
Spring-常用注解
java·数据库·spring·注解
三小尛18 分钟前
C++赋值运算符重载
开发语言·c++
籍籍川草21 分钟前
JVM指针压缩的那些事
java·开发语言·jvm
小徐不徐说29 分钟前
C++ 模板与 STL 基础入门:从泛型编程到实战工具集
开发语言·数据结构·c++·qt·面试
艾莉丝努力练剑30 分钟前
【C/C++】类和对象(上):(一)类和结构体,命名规范——两大规范,新的作用域——类域
java·c语言·开发语言·c++·学习·算法
myNameGL43 分钟前
下载一个JeecgBoot-master项目 导入idea需要什么操作启动项目
java·ide·intellij-idea
AQin10121 小时前
IP 🆚 MAC,你分得清吗?
后端·网络协议