【转】HashSet的用法

原文网址:http://blog.csdn.net/aidesudi/article/details/4720201

Java代码

  1. public class TestHashSet {
  2. public static void main(String [] agrs){
  3. Set set = new HashSet();
  4. //添加一个string数据
  5. set.add("文本");
  6. //添加一个整数数据
  7. set.add(new Integer(5));
  8. //添加一个付点数据
  9. set.add(12.15);
  10. //输出集合大小
  11. System.out.println(set.size());
  12. //在添加个相同的文本
  13. set.add("文本");
  14. //输出大小
  15. System.out.println(set.size());
  16. //添加个null值
  17. set.add(null);
  18. //输出集合大小
  19. System.out.println(set.size());
  20. //再添加个null值
  21. set.add(null);
  22. //输出集合大小
  23. System.out.println(set.size());
  24. //判断是否存在null值
  25. System.out.println(set.contains(null));
  26. // 删除null值
  27. set.remove(null);
  28. //判断是否存在null值
  29. System.out.println(set.contains(null));
  30. //输出集合大小
  31. System.out.println(set.size());
  32. Set set1 = new HashSet();
  33. UserInfo user = new UserInfo("abc","123");
  34. UserInfo user1 = new UserInfo("abc","123");
  35. set1.add(user);
  36. System.out.println(set1.size());
  37. //判断是否存在user1这个对象
  38. System.out.println(set1.contains(user1));
  39. user.setName("xyz");
  40. user.setPassword("aaa");
  41. //在更改了user值后user1还存在吗?
  42. System.out.println(set1.contains(user1));
  43. }
  44. }
  45. public class UserInfo {
  46. private String name;
  47. private String password;
  48. private int HASHCODE= Integer.MIN_VALUE;
  49. public UserInfo(String name,String password){
  50. this.name = name;
  51. this.password = password;
  52. }
  53. public String getName() {
  54. return name;
  55. }
  56. public void setName(String name) {
  57. this.name = name;
  58. }
  59. public String getPassword() {
  60. return password;
  61. }
  62. public void setPassword(String password) {
  63. this.password = password;
  64. }
  65. public int hashCode() {
  66. if (HASHCODE == Integer.MIN_VALUE) {
  67. // 重新生成本类的hashCode
  68. HASHCODE = name.hashCode() + password.hashCode();
  69. }
  70. return HASHCODE;
  71. }
  72. //判断值是否相等
  73. public boolean equals(Object obj) {
  74. if(obj == null || !(obj  instanceof  UserInfo)){
  75. return false;
  76. }
  77. UserInfo user = (UserInfo)obj;
  78. return this.name == user.name && this.password ==  user.password;
  79. }
  80. }

从上面的简单添加,和输出结果我想大家已经知道了set的一些用法和特性了。

1.    HashSet允许null值。

2.       HashSet中值不能重复。

3.       Hashset在判断是否存在同一个对象的时候首先会判断对象的hashcode是否相等,然后在判断对象的equals()是否相等。当你向HashSet中存入重复元素时,他会按照正常的流程执行存入操作
底层的数据结构采用的是数组+链表的存储结构(明白这一点对于理解HashSet的原理非常重要),
也就是说数组中的每一个元素都是一个链表(对应java中的List的某一具体实现),
这样当有元素要存入HashSet中时,便会首先通过hashCode()方法得到该对象的一个哈希码,并利用该哈希码通过一些转换算法映射成数组的下标索引(当查找时也是如此,因此会非常的快),接下来便会判断该下标处是否为null若为null则会创建一个列表,此时将待插入的对象直接插入,若列表已经存在则利用equals()方法将带插入对象与列表中的元素逐个比较,相等则忽略,不存在相等元素则直接插入。
因此不同对象的hashCode()是可以相同的(最好是均匀的散列开,这样才能充分的提高访问及插入的速度),
根据equals()判定相等的对象所产生的hashCode()必须相等(根据其原理不难理解,否则的话便会有重复元素出现了)
保证一点  hashCode()与equals()必须能够唯一的确定一个对象。

时间: 2024-10-05 00:15:32

【转】HashSet的用法的相关文章

计算机程序的思维逻辑 (41) - 剖析HashSet

上节介绍了HashMap,提到了Set接口,Map接口的两个方法keySet和entrySet返回的都是Set,本节,我们来看Set接口的一个重要实现类HashSet. 与HashMap类似,字面上看,HashSet由两个单词组成,Hash和Set,Set表示接口,实现Set接口也有多种方式,各有特点,HashSet实现的方式利用了Hash. 下面,我们先来看HashSet的用法,然后看实现原理,最后我们总结分析下HashSet的特点. 用法 Set接口 Set表示的是没有重复元素.且不保证顺序

【集合】

1.1集合简介 在前面学习了Java数组,Java数组的长度是固定的,在同一个数组中只能存放相同类型的数据.数组可以存放基本类型的数据,也可以存放引用类型的数据. 在创建Java数组时,必须明确指定数组的长度.数组一旦创建,其长度就不能被改变.在许多应用中,一组数据的数目是不固定的.比如一个单位的员工数目是变化的.有老员工跳槽,也有新员工进来. 为了使程序能方便地存储和操纵数目不固定的一组数据,JDK类库提供了Java集合,所有Java集合类都位于java.util包中.与Java数组不同,Ja

Sub的构造函数抛出了Exception异常增加新的catch块才能解决

在使用mingw64之前,由于其支持较多的编译类型,所以其安装包较多,通常采用的是“穷举+回溯”的思想,即从入口开始,顺着某一个方向出发,若能够走通,就继续往前走:若不能走通,则退回原路,换一个方向继续向前探索,直到所有的通路都探寻为止.因此本文依据这种“穷举+回溯”的思想,设计一个求解迷宫的程序. 鱼目混珠者有高明之处,左右逢源之能,这本无可厚非,但如果一种投机的技术态度,堂而皇之的成为青年的学习榜样,作为对技术有态度.有坚持的我,在此时此刻,有义务,甚至要义无反顾的站出来反对并碾碎这样的丑恶

Java HashSet和LinkedHashSet的用法

Java HashSet和LinkedHashSet的用法 类HashSet和LinkedHashSet都是接口Set的实现,两者都不能保存重复的数据.主要区别是HashSet不保证集合中元素的顺序,即不能保证迭代的顺序与插入的顺序一致. 而LinkedHashSet按照元素插入的顺序进行迭代,即迭代输出的顺序与插入的顺序保持一致. 以下是HastSet和LinkedHashSet的用法示例: [java] view plain copy import java.util.Collections

转载:C# HashSet 用法

原文地址:http://www.cnblogs.com/xiaopin/archive/2011/01/08/1930540.html   感谢博主分享! NET 3.5在System.Collections.Generic命名空间中包含一个新的集合类:HashSet<T>.这个集合类包含不重复项的无序列表.这种集合称为“集(set)”.集是一个保留字,所以该类有另一个名称HashSet<T>.这个名称很容易理解,因为这个集合基于散列值,插入元素的操作非常快,不需要像List<

C#中泛型容器Stack&lt;T&gt;的用法,以及借此实现&rdquo;撤销/重做&rdquo;功能

.Net为我们提供了众多的泛型集合.比如,Stack<T>先进后出,Queue<T>先进先出,List<T>集合元素可排序,支持索引,LinkedList<T>,双向链表的泛型实现,不支持索引;ISet<T>不允许被复制,他有2个实现,一个是HashSet<T>,不维持集合元素的排序,另一个是SortedSet<T>,支持集合元素的排序;IDictionary<TKey, TValue>是一个字典集合的泛型接口

Jedis基本用法

Redis(Remote Dictionary Server,远程数据字典服务器)是一个开源的高性能内存数据库,常用作缓存缓存服务器使用,也已做消息队列使用.因其高性能.丰富的数据类型.可扩展等特性受开发者青睐,这里介绍在java中使用Jedis操作Redis的基本用法. 1. 字符串String. package com.zws.redis; import java.util.concurrent.TimeUnit; import redis.clients.jedis.Jedis; publ

Java操作Redis之Jedis用法详解

Redis(Remote Dictionary Server,远程数据字典服务器)是一个开源的高性能内存数据库,常用作缓存缓存服务器使用,也已做消息队列使用.因其高性能.丰富的数据类型.可扩展等特性受开发者青睐,这里介绍在java中使用Jedis操作Redis的基本用法. 1. 字符串String. package com.zws.redis.examples; import java.util.concurrent.TimeUnit; import redis.clients.jedis.Je

ArrayList、LinkedList、 Vector、Map 用法比较

ArrayList和Vector是采用数组方式存储数据,此数组元素总数大于实际存储的数据个数以便增加和插入元素,二者都允许直接序号索引元素,但是插入数据要移动数组元素等内存操作,所以它们索引数据快.插入数据慢. ArrayList数组存储方式: [java] view plaincopyprint? private transient Object[] elementData; public ArrayList(int initialCapacity) { super(); if (initia