随笔 - 51  文章 - 0  评论 - 9  阅读 - 27万

HashSet与HashMap的区别

HashSet与HashMap的区别

1.HashSet:

  HashSet实现了Set接口,它不允许集合中出现重复元素。当我们提到HashSet时,第一件事就是在将对象存储在

HashSet之前,要确保重写hashCode()方法和equals()方法,这样才能比较对象的值是否相等,确保集合中没有

储存相同的对象。如果不重写上述两个方法,那么将使用下面方法默认实现:

 public boolean add(Object obj)方法用在Set添加元素时,如果元素值重复时返回 "false",如果添加成功则返回"true"


2.HashMap:

  HashMap实现了Map接口,Map接口对键值对进行映射。Map中不允许出现重复的键(Key)。Map接口有两个基本的实现

TreeMap和HashMap。TreeMap保存了对象的排列次序,而HashMap不能。HashMap可以有空的键值对(Key(null)-Value(null))

HashMap是非线程安全的(非Synchronize),要想实现线程安全,那么需要调用collections类的静态方法synchronizeMap()实现。

public Object put(Object Key,Object value)方法用来将元素添加到map中。

 

3.HashSet与HashMap的区别:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
(1)HashMap                                
    a.实现了Map接口                         
    b.存储键值对                            
    c.调用put()向map中添加元素             
    d.HashMap使用键(Key)计算Hashcode    
    e.HashMap相对于HashSet较快,             
    因为它是使用唯一的键获取对象         
(2)HashSet
    a.实现Set接口
    b.仅存储对象
    c.调用add()方法向Set中添加元素
    d.HashSet使用成员对象来计算hashcode值,
      对于两个对象来说hashcode可能相同,
      所以equals()方法用来判断对象的相等性,
      如果两个对象不同的话,那么返回false
    e.HashSet较HashMap来说比较慢

 

  

posted on   鲁班快跑  阅读(7260)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示