ArrayList 和 LinkedList 的区别

线程安全:

  • ArrayList 和 LinkedList 都是线程不安全的, 它们的方法之间都是不同步的.

底层数据结构:

  • ArrayList 底层是使用 Object 数组;
  • LinkedList 底层是使用双向链表数据结构.

快速访问随机元素:

  • ArrayList 支持高效的快速访问随机元素, 而 LinkedList 不支持.

占用内存:

  • ArrayList 的空间浪费主要体现在它会在 list 列表结尾预留一定的容量空间.
  • LinkedList 的空间浪费主要体现在它的每一个元素都要比 ArrayList 占用更大的空间, 因为双向链表需要存放直接前驱和直接后继还有元素本身.

你可能感兴趣的:(ArrayList 和 LinkedList 的区别)