简单实现HashSet+ HashSet和HashMap的区别

简单实现HashSet

因为HashSet的底层是用HashMap实现的,key值为传进来的对象,value都为HashSet类里面定义好的静态Object类,HashSet的许多方法都是直接调用HashMap的方法,并且它的方法几乎只是collection接口的实现,所以很容易理解,这里直接放代码(简单几个方法的实现)。

package myCollection;

import java.util.HashMap;

/**
 * 简单实现HashSet
 * TODO
 * @version 1.0
 * @author 王星宇
 */
public class myHashSet {
	/**
	 * map 作为key,PRESENT作为固定的value
	 */
	HashMap map;
	private static final Object PRESENT = new Object();
	/**
	 * 构造函数,初始化一个HashMap
	 */
	public myHashSet() {
		map = new HashMap();
	}
	/**
	 * 直接调用HashMap的put()方法	
	 * @param obj 
	 */
	public void add(Object obj) {
		map.put(obj, PRESENT);
	}
	/**
	 * 直接调用map的size()方法
	 * @return
	 */
	public int size() {
		return map.size();
	}
}

HashSet和HashMap的区别

因为HashSet底层就是用HashMap实现的,所以二者区别并不大,我找了几篇博客,差不多都是这张表格,除了“理所当然”的区别,最主要的区别是二者比较是否相同的方式不同。

HashMapHashSet
HashMap实现了Map接口HashSet实现了Set接口
HashMap储存键值对HashSet仅仅存储对象
使用put()方法将元素放入map中使用add()方法将元素放入set中
HashMap中使用键对象来计算hashcode值HashSet使用成员对象来计算hashcode值,对于两个对象来说hashcode可能相同,所以equals()方法用来判断对象的相等性,如果两个对象不同的话,那么返回false
HashMap比较快,因为是使用唯一的键来获取对象HashSet较HashMap来说比较慢
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值