`
啸笑天
  • 浏览: 3468095 次
  • 性别: Icon_minigender_1
  • 来自: China
社区版块
存档分类
最新评论

HashSet和HashMap

    博客分类:
  • java
 
阅读更多

当在HashMap中添加key-value对,由其key的hashCode()返回值决定改key-value对的存储位置,当key-value对的key的hashCode()返回值相同时,key-value对的value将由key通过eqauls()比较值决定是采用覆盖行为(返回true)(key不做改变),还是产生key-value链(返回false)。
import java.util.*;
class Name
{
    private String first;
	private String last;
    public Name(String first, String last) 
	{
        this.first = first;
        this.last = last;
    }
	//根据first判断两个Name是否相等
    public boolean equals(Object o) 
	{
		if (this == o)
		{
			return true;
		}
		if (o.getClass() == Name.class)
		{
			Name n = (Name)o;
			return n.first.equals(first);
		}
		return false;
    }
	//根据first计算Name对象的hashCode()返回值
    public int hashCode()
	{
		return first.hashCode();
    }
	public String toString()
	{
		return "Name[first=" + first + ", last=" + last + "]";
	}
}
public class HashSetTest2
{
	public static void main(String[] args) 
	{
		HashMap<Name,String> set = new         HashMap<Name,String>(); 
		set.put(new Name("abc" , "123"),"1111111");
		set.put(new Name("abc" , "456"),"2222222");
		System.out.println(set);
	}
}
 输出:
{Name[first=abc, last=123]=2222222}
即key没变,value变了。

HashSet的实现只是封装了一个HashMap对象来存储所有的集合元素。所有放入HashSet中的集合元素实际上由HashMap的key来保存,而HashMap的value则存储了一个PRESENT,它是一个静态的Object对象。
由于HashSet的add()方法添加集合元素时实际上转变为调用HashMap的put()方法添加key-value对,当新放入HashMap的key-value对中key与集合中原有key-value对中的key相同(hashCode()返回值相等,通过eqauls()比较值也相等)时,新添加的key-value对的value将覆盖原来key-value对的value,但key不会有任何改变。因此,如果向HashSet中添加一个已经存在的元素,新添加的集合元素(底层由HashMap的key保存)不会覆盖已有的集合元素。
把上面代码main方法中改为:
HashSet<Name> set = new HashSet<Name>();
set.add(new Name("abc" , "123"));
set.add(new Name("abc" , "456"));
System.out.println(set);
则输出:
[Name[first=abc, last=123]]
即key没变


注意:在试图把某个对象当成HashMap的key,或者试图将这个类的对象放入HashSet中保存时,重写该类的equals(Object obj)方法和hashCode()方法很重要,而且这两个方法的返回值必须一致。当该类的两个hashCode()返回值相同时,它们通过equals(Object obj)方法比较也应该返回true。通常来说,所有参与计算hashCode()返回值的关键属性,都应该用于作为equals(Object obj)比较的标准。
例如下面代码运行显示的是false,那是因为没有重写hashCode()方法。
import java.util.*;
/**
 * Description:
 * <br/>网站: <a href="http://www.crazyit.org">疯狂Java联盟</a> 
 * <br/>Copyright (C), 2001-2010, Yeeku.H.Lee
 * <br/>This program is protected by copyright laws.
 * <br/>Program Name:
 * <br/>Date:
 * @author  Yeeku.H.Lee kongyeeku@163.com
 * @version  1.0
 */
class Name
{
    private String first;
	private String last;
    public Name(String first, String last) 
	{
        this.first = first;
        this.last = last;
    }
    public boolean equals(Object o) 
	{
		if (this == o)
		{
			return true;
		}
		if (o.getClass() == Name.class)
		{
			Name n = (Name)o;
			return n.first.equals(first)
				&& n.last.equals(last);
		}
		return false;
    }
}
public class HashSetTest
{
	public static void main(String[] args) 
	{
		Set<Name> s = new HashSet<Name>();
		s.add(new Name("abc", "123"));
		System.out.println(
			s.contains(new Name("abc", "123")));
	} 
}
 


 

分享到:
评论

相关推荐

    Java中HashSet和HashMap的区别_动力节点Java学院整理

    Map接口有两个基本的实现,HashMap和TreeMap。TreeMap保存了对象的排列次序,而HashMap则不能。HashMap允许键和值为null。HashMap是非synchronized的,但collection框架提供方法能保证HashMap synchronized,这样多...

    1.HashSet和HashMap遍历.md

    自己写的例子,关于HashSet遍历和HashMap遍历的. 感谢大家参考

    HashSet和HashMap的区别_动力节点Java学院整理

    HashSet实现了Set接口,它不允许集合中有重复的值,当我们提到HashSet时,第一件事情就是在将对象存储在HashSet之前,要先确保对象重写equals()和hashCode()方法,这样才能比较对象的值是否相等,以确保set中没有...

    Java集合框架源码剖析:HashSet 和 HashMap

     之所以把HashSet和HashMap放在一起讲解,是因为二者在Java里有着相同的实现,前者仅仅是对后者做了一层包装,也是说HashSet里面有一个HashMap(适配器模式)。因此本文将重点分析HashMap。  HashMap实现了Map...

    JavaHashSet和HashMap源码剖析编程开发技术

    在Java编程语言中,HashSet和HashMap是两种非常重要的集合类,它们都位于`java.util`包下,分别用于存储不重复元素的集合和键值对的数据结构。本篇技术文档将深入剖析这两类数据结构的源码,帮助开发者理解其内部...

    Java HashMap类详解

    HashSet 和 HashMap 之间有很多相似之处,对于 HashSet 而言,系统采用 Hash 算法决定集合元素的存储位置,这样可以保证能快速存、取集合元素;对于 HashMap 而言,系统 key-value 当成一个整体进行处理,系统总是...

    treemap treeset hashset hashmap 简要介绍

    在Java编程语言中,集合框架提供了多种数据结构来存储和操作数据,其中`TreeMap`、`TreeSet`、`HashSet`以及`HashMap`是最常用的数据结构之一。这些集合类各自有着独特的特性和应用场景,下面将对它们进行详细介绍。...

    HashMap与HashTable和HashSet的区别

    ### HashMap与HashTable和HashSet的区别 #### 一、概述 在Java集合框架中,`HashMap`, `HashTable` 和 `HashSet` 是三个重要的数据结构,它们分别实现了`Map`接口和`Set`接口,提供了不同的功能来满足不同的编程...

    Java Methods-Lookup Tables and Hashing.ppt

    Java 方法lookup表和哈希表 Java 方法是一种面向对象的编程语言,广泛应用于安卓应用开发、Web 开发、...但是,HashSet 和 HashMap 的实现细节不同,HashSet 使用链式技术来解决哈希碰撞,而 HashMap 使用探测技术。

    ArrayList-HashSet-HashMap.zip_ABC_arraylist_hashmap_学生 信息 txt

    编写一个查询类,输入学生学号,若该生在数据文件(test.txt)中存在,在JTextArea中显示该生信息 若该生在数据文件(test.txt)中不存在,显示...在输出中,能显示该生的总成绩和平均成绩,将显示结果存盘(例如存入“abc.txt”)

    集合框架的各自区别.pdf

    在日常开发中,ArrayList、HashSet和HashMap是最常用的集合类型。ArrayList提供了快速的随机访问,适用于大部分情况;HashSet提供了快速查找和去重功能;HashMap则通过键的哈希值实现快速查找。在多线程环境下,需...

    Java编程技巧.pdf

    综上所述,熟练掌握HashSet和HashMap的使用是Java开发中不可或缺的技能。通过不断的实践和学习,可以积累丰富的编码经验,提高代码质量和效率。在实际开发中,灵活运用这些技巧,不仅可以编写出高质量的代码,还能...

    JAVA COLLECTION (APress)

    本书涵盖了ArrayList、LinkedList、HashSet、HashMap等核心接口和类,以及它们的实现细节。读者将学习如何高效地使用这些集合类,包括添加、删除、查找元素,以及如何根据具体需求选择合适的数据结构。 ArrayList和...

    Java常见面试题(线程、集合、设计模式).zip

    面试中,你可能需要解释这些集合的区别,比如ArrayList和LinkedList的插入和删除性能,或者HashSet和HashMap的查找效率。另外,泛型、迭代器和流API(Java 8及以上版本)的使用也是考察点。 最后,设计模式是软件...

    深入探索Java集合框架:解密复杂的面试题和精准解析

    4. **HashMap和Hashtable的区别** - **HashMap** 非线程安全,允许null键和null值,适合单线程环境。 - **Hashtable** 线程安全,不允许null键和null值,适合多线程环境。 5. **ConcurrentHashMap和Hashtable的...

    Java 集合学习指南 - v1.1.pdf

    此外,集合之间的比较,例如HashSet和HashMap,虽然它们都可以存储不重复的元素,但HashSet更适用于快速查找,而HashMap则提供了键值对的映射能力。在学习这些集合时,理解它们的特性和应用场景,以及它们在源码层面...

    Java 实例 - 删除集合中指定元素源代码+详细指导教程.zip

    我们将会探讨ArrayList、LinkedList、HashSet和HashMap等常见集合类的删除操作,并理解它们的区别。 首先,让我们从ArrayList开始。ArrayList是基于数组实现的集合,提供了快速的随机访问。删除一个元素可以使用`...

    java 中HashMap、HashSet、TreeMap、TreeSet判断元素相同的几种方法比较

    这些数据结构用于存储和管理数据,其中HashMap和HashSet是基于哈希表实现的,而TreeMap和TreeSet则是基于红黑树(Red-Black Tree)实现的。在处理元素重复性时,它们有不同的策略和效率。 **HashMap** HashMap是一...

    JCF.zip_zip

    HashSet和HashMap分别是Set和Map的常见实现,HashMap提供快速查找,而HashSet依赖于HashMap实现。 3. **方法与操作**:JCF提供了丰富的操作方法,如add、remove、contains、get、put等,以及迭代器Iterator和...

    HashSet的实现原理

    由于HashMap的内部实现是基于散列表的,因此HashSet的查找和插入操作的时间复杂度都近似为O(1),前提是散列函数能将元素分布均匀。 关于HashSet与HashMap的区别,在底层数据结构上,二者都基于哈希表,但存储的方式...

Global site tag (gtag.js) - Google Analytics