博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HashSet与HashMap的区别
阅读量:7013 次
发布时间:2019-06-28

本文共 1029 字,大约阅读时间需要 3 分钟。

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)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来说比较慢

 

  

转载于:https://www.cnblogs.com/zhusf/p/10572350.html

你可能感兴趣的文章
PHPstorm 优化、设置与提速篇
查看>>
[iOS] 从 application delegate 引申三点
查看>>
深入理解Java虚拟机(一)
查看>>
实战Android 上推下拉——隐藏、显示ActionBar
查看>>
PowerShell 多线程测试IP端口
查看>>
使用SQL Server 2008 Extended Events SSMS Addin轻松管理XEvents
查看>>
Django-celery 安装及使用测试
查看>>
优秀UML制图开源工具--ArgoUML
查看>>
没有服务台,就没有ITSM
查看>>
加点自已内容的新内核下L7-FILTER的应用实例!
查看>>
QQ-weiyun(微云)-云储存
查看>>
微信公众帐号开发教程第3篇-开发模式启用及接口配置(转)
查看>>
.NET项目web自动化测试实战——Selenium 2.0
查看>>
Asp.Net SignalR - 持久连接类
查看>>
11.8. NAT
查看>>
火车票秒杀攻略
查看>>
关于Asp.Net中FileUpload控件属性PostedFile.ContentType的提示
查看>>
使用shell批量生成数据整合式迁移的脚本
查看>>
Unicode字符编码标准
查看>>
云计算就像是产业链的重新组合
查看>>