Java中List、Set、Map的区别和实现方式

news/2024/11/20 2:27:37/

Java中List、Set、Map的区别和实现方式

List

  • List 是一个有序的集合,即元素按照插入的顺序进行排序,可以有重复的元素。
  • 因为是有序的,所以可以根据下标来获取元素或者遍历整个集合内的元素。
  • 常用的实现类包括 ArrayList 和 LinkedList。

ArrayList

  • 底层是基于数组实现的,在内部维护了一个 Object[] 数组。
  • 当需要添加元素时,首先检查数组是否已满,如果未满,就直接在后面添加元素,否则需要通过扩容数组的方式来增加容量。
  • 由于数组长度固定且数组内的元素是连续的,因此查询某个元素的时间复杂度为 O(1),而添加或删除元素的时间复杂度为 O(n)(需要移动后面的元素)。

LinkedList

  • 底层是基于链表实现的,每个节点包含一个元素和指向下一个节点的引用。
  • 当需要添加(尾部添加O(1))或删除(删除头结点或者使用 iterator 的 remove 方法 O(1))元素时,只需要修改相邻节点之间的引用,不需要对其他元素进行移动。这使得 LinkedList 在添加或删除元素方面比 ArrayList 更快。
  • 由于没有连续的内存,并且需要遍历整个链表才能找到指定元素,因此查询某个元素的时间复杂度为 O(n),而添加或删除元素的时间复杂度为 O(1)。

Set

  • Set 是一个不允许有重复元素的集合,元素没有特定的顺序。
  • 可以用来判断某个元素是否在集合¥¥现过。
  • 常用的实现类包括 HashSet 和 TreeSet。

HashSet

  • 底层是基于 HashMap 来实现的,内部维护了一个 HashMap 实例作为其成员变量。
  • 添加元素时,将元素作为 key 存储在 HashMap 中,value 为一个固定的常量对象。
  • 由于 HashMap 底层使用了哈希表,因此可以快速查找某个元素是否已存在集合中,时间复杂度为 O(1)。
  • 不保证遍历顺序,也不保证插入顺序。

TreeSet

  • 底层是基于红黑树实现的,每个元素都必须实现 Comparable 接口或向构造函数传递一个 Comparator 对象。
  • 每个节点对应一个元素,且每个节点具有以下性质:
    • 如果一个节点有左子节点,则左子节点上的所有元素都比该节点上的元素小;
    • 如果一个节点有右子节点,则右子节点上的所有元素都比该节点上的元素大;
    • 左右子树自身都是一棵二叉搜索树。
  • 由于 TreeSet 底层采用了红黑树,因此平均情况下添加元素、删除元素、查找元素的时间复杂度都为 O(logn)。
  • 确保元素按升序排列,或者在创建时通过传递 Comparator 实例来自定义排序方式。

Map

  • Map 是一个键值对映射的集合,允许键和值都可以为 null,但键不能重复,值可以重复。
  • 可以用于存储一些关联性比较强的数据对象,例如电话簿、字典等。
  • 常用的实现类包括 HashMap 和 TreeMap。

HashMap

  • 底层也是基于哈希表来实现的,内部维护了一个数组,每个元素都是一个链表或树的首节点,用于解决哈希冲突。
  • 添加元素时,会根据 key 的 hash 值进行散列,然后找到对应的数组位置,如果该位置上已经存在元素,则以链表或树结构的形式将其插入。
  • HashMap 可以快速查找某个 key 对应的 value 是否存在集合中,时间复杂度为 O(1)(如果哈希函数设计得好)。
  • 遍历顺序和插入顺序都不保证。

TreeMap

  • 底层是基于红黑树实现的,每个键值对都被封装成一个 Entry 对象,按照键的自然顺序或指定 Comparator 排序。
  • TreeMap 中的所有元素都保证按照排序规则排列,在遍历 TreeMap 时可以获得有序的键值对列表。
  • 添加、删除、查找元素的时间复杂度都为 O(logn),其中 n 表示元素个数。
  • TreeMap 可以自定义排序方式,并且支持限制只允许包含实现了 Comparable 接口的键类型。

总结

List

List是Java集合框架中最基本和最常用的一种数据结构,它是有序集合,可以允许重复的元素。List提供了按照索引来插入、删除和获取指定位置上的元素等操作。

Java中List有很多实现类,比较常用的有:

  • ArrayList:基于数组实现,以及动态扩容。
  • LinkedList:基于链表实现,适合于频繁添加、删除元素操作。

Set

Set也是Java集合框架中的一种数据结构,它是由不同元素组合而成的无序集合,不允许有重复元素。Set的主要目的是为了消除重复元素。

Java中Set的实现类有:

  • HashSet:基于哈希表实现,可快速判断对象的唯一性。
  • TreeSet:基于红黑树实现,可以对元素排序并保证元素唯一性。
  • LinkedHashSet:基于哈希表和链表实现,保留插入时顺序并保证元素唯一性。

Map

Map也是Java集合框架中最常用的一种数据结构,它是由键值对组成的集合,每个键只能出现一次,而且每个键只能映射到一个值。

Java中Map有很多实现类,比较常用的有:

  • HashMap:基于哈希表实现,以键值对的形式进行存储和访问。
  • TreeMap:基于红黑树实现,可以对键进行排序并保证键的唯一性。
  • LinkedHashMap:基于哈希表和链表实现,按照插入顺序维护元素的次序。

http://www.ppmy.cn/news/404474.html

相关文章

PAT 1080. Graduate Admission (30)

算法思想:首先对所有学生按成绩排序,然后依次放入各个学校(过程中注意是否排名和该学校最后一名一样) 算法的主要步骤如下: 首先,根据申请者的总分和 GE 分数对申请者列表进行排序,将总分高的…

高通Kryo 架构

高通Kryo架构 Kryo Kryo是Qualcomm Technologies推出的首款定制设计的64位CPU。Kryo采用最新14纳米FinFET工艺制程,拥有四个核心,单核支持最高达2.2GHz的处理速度,与骁龙810处理器相比,Kryo CPU在性能方面将带来最高达两倍的提升…

Qualcomm 处理器 Krait架构

Krait是美国高通公司基于ARMv7-A指令集、自主设计的采用28纳米工艺的全新处理器微架构。能够实现每个内核最高运行速度可达2.5GHz,较高通第一代的Scorpion CPU微架构在性能上提高60%以上,并将功耗降低65%。 骁龙移动智能处理器的S4系列多数使用了Krait …

什么是SoC(System-on-a-Chip)

SoC SoC的全称叫做:System-on-a-Chip,中文的的意思就是“把系统都做在一个芯片上”,如果在PC时代我们说一个电脑的核心是CPU,那么在智能终端时代,手机的核心就是这个SoC。 这么说是因为SoC上集成了很多手机上最关键的…

【Unity3D】unity-mono编译libmono.so成功

目录 文章最终成功编译出libmono.so如下图所示,历时9天 一、下载文件配置环境 二、下载Unity-Mono库 三、正式开始编译libmono.so 1、libmono.so编译文件基础说明 2、修改相关文件(及其重要) ① 修改/home/用户名/mono/external/build…

ARM Cortex-X1架构 自研的终结者

随着麒麟9000和三星Exynos 1080的发布,Android手机芯脏领域正式进入了5nm时代。可惜,麒麟9000的CPU架构仍然停留在ARM去年发布的Cortex-A77阶段,而Exynos 1080虽然用上了ARM最新发布的Cortex-A78,但出于定位的原因它并没能引入AMD…

kruskal算法

kruskal算法(读者可以将其读作“克鲁斯卡尔算法”)同样是解决最小生成树问题的一个算法。和prim算法不同,kruskal算法采用了边贪心的策略,其思想极其简洁,理解难度比prim算法要低很多。 kruskal算法的基本思想为&…

ARM架构及ARM指令集、Thumb指令集你了解多少?

ARM架构及ARM指令集、Thumb指令集你了解多少? 1991 年ARM 公司成立于英国剑桥,在成立后的那几年,ARM业绩平平,工程师们也人心惶惶,害怕随时都会失业。在这个情况下,ARM决定改变他们的产品策略——他们不再生…