当前位置:   article > 正文

HashMap与HashSet的区别_hashset hashmap区别

hashset hashmap区别

HashMap和HashSet都是Java集合框架中的结构,它们之间有以下区别:

  1. 存储方式:HashMap是基于键值对(key-value pair)的存储结构,每个元素都有一个key和一个对应的value;HashSet是基于哈希表(hash table)的存储结构,只存储元素的值。

  2. 元素的唯一性:HashMap中的key是唯一的,不允许重复;HashSet中的元素也是唯一的,不允许重复。

  3. 排序:HashMap中的元素是无序存储的,即添加元素的顺序不会影响遍历的顺序;HashSet中的元素也是无序存储的。

  4. 访问速度:HashMap通过使用key来访问value,所以可以通过key快速查找、插入和删除元素;HashSet只能通过元素的值来访问和操作集合,具有快速查找、插入和删除元素的特性。

        hashMap:HashMap实现了Map接口,HashMap储存键值对,使用put()方法将元素放入map中,HashMap中使用键对象来计算hashcode值,HashMap比较快,因为是使用唯一的键来获取对象。

        HashSet实现了Set接口,HashSet仅仅存储对象,使用add()方法将元素放入set中,HashSet使用成员对象来计算hashcode值,对于两个对象来说hashcode可能相同,所以equals()方法用来判断对象的相等性,如果两个对象不同的话,那么返回false。HashSet较HashMap来说比较慢。

综上所述,HashMap适用于需要通过key-value对来存储和访问元素的场景,而HashSet适用于只需要存储元素值并且需要保证元素的唯一性的场景。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/643845
推荐阅读
相关标签
  

闽ICP备14008679号