ArrayList 和 LinkedList 的区别

线程安全:

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

底层数据结构:

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

快速访问随机元素:

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

占用内存:

  • ArrayList 的空间浪费主要体现在它会在 list 列表结尾预留一定的容量空间.
  • LinkedList 的空间浪费主要体现在它的每一个元素都要比 ArrayList 占用更大的空间, 因为双向链表需要存放直接前驱和直接后继还有元素本身.
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容