赞
踩
HashMap和HashSet都是Java集合框架中的结构,它们之间有以下区别:
存储方式:HashMap是基于键值对(key-value pair)的存储结构,每个元素都有一个key和一个对应的value;HashSet是基于哈希表(hash table)的存储结构,只存储元素的值。
元素的唯一性:HashMap中的key是唯一的,不允许重复;HashSet中的元素也是唯一的,不允许重复。
排序:HashMap中的元素是无序存储的,即添加元素的顺序不会影响遍历的顺序;HashSet中的元素也是无序存储的。
访问速度: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适用于只需要存储元素值并且需要保证元素的唯一性的场景。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。