HashSet与HashMap的区别
来源:互联网 发布:尚学堂大数据极限班 编辑:程序博客网 时间:2024/06/07 08:56
面试中经常被问到HashMap与HashSet的区别。于是本渣静下心来总结了一下HashSet与HashMap的区别。
先了解一下HashMap跟HashSet
HashSet:
HashSet实现了Set接口,它不允许集合中出现重复元素。当我们提到HashSet时,第一件事就是在将对象存储在
HashSet之前,要确保重写hashCode()方法和equals()方法,这样才能比较对象的值是否相等,确保集合中没有
储存相同的对象。如果不重写上述两个方法,那么将使用下面方法默认实现:
public boolean add(Object obj)方法用在Set添加元素时,如果元素值重复时返回 "false",如果添加成功则返回"true"
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中。
HashSet与HashMap的区别:
HashMapHashSet实现了Map接口实现Set接口存储键值对仅存储对象调用put()向map中添加元素调用add()方法向Set中添加元素HashMap使用键(Key)计算HashcodeHashSet使用成员对象来计算hashcode值,
对于两个对象来说hashcode可能相同,
所以equals()方法用来判断对象的相等性,
如果两个对象不同的话,那么返回false
HashMap相对于HashSet较快,因为它是使用唯一的键获取对象HashSet较HashMap来说比较慢- HashSet与HashMap的区别
- HashSet与HashMap的区别
- HashMap与HashSet的区别
- HashSet与HashMap的区别
- HashMap与HashSet区别
- HashSet与HashMap的区别与联系
- Map与HashMap,Hashtable,HashSet的区别
- Map与HashMap,Hashtable,HashSet的区别
- Map与HashMap,Hashtable,HashSet的区别
- java 中hashset 与hashmap的区别
- HashMap与HashTable的区别 |HashSet和HashMap的区别
- HashMap与HashTable的区别、HashMap与HashSet的关系
- HashMap与HashTable的区别、HashMap与HashSet的关系
- HashMap与HashTable的区别、HashMap与HashSet的关系
- HashMap与HashTable的区别、HashMap与HashSet的关系
- hashset,hashmap的区别
- HashSet与HashTable hashMap区别
- HashSet,HashMap与HashTable的关系与区别
- 11.2
- 学生管理系统三
- 我是一个打了激素的数组
- C语言之static关键字的使用
- IM 即时通讯单例发送消息
- HashSet与HashMap的区别
- CCITT标准G726编解码实例
- GCC高级测试功能扩展——程序性能测试工具gprof、程序覆盖测试工具gcov
- 安装JDK
- [笔记]渗透测试基础
- MVP
- [BFS] HDU 2612
- 83-Remove Duplicates From Sorted List
- 使用脚本发送命令到控制台