一. HashSet源代码 
HashSet 的实现  
 
对于 HashSet 而言,它是基于 HashMap 实现的,HashSet 底层采用 HashMap 来保存所有元素,因此 HashSet 的实现比较简单,查看 HashSet 的源代码,可以看到如下代码:  Java代码  
public class HashSet<E>    extends AbstractSet<E>    
implements Set<E>, Cloneable, java.io.Serializable    {    
 // 使用 HashMap 的 key 保存 HashSet 中所有元素    private transient HashMap<E,Object> map;    
 // 定义一个虚拟的 Object 对象作为 HashMap 的 value     private static final Object PRESENT = new Object();     ...    
 // 初始化 HashSet,底层会初始化一个 HashMap     public HashSet()     {    
     map = new HashMap<E,Object>();     }    
 // 以指定的 initialCapacity、loadFactor 创建 HashSet     // 其实就是以相应的参数创建 HashMap    
 public HashSet(int initialCapacity, float loadFactor)     {    
     map = new HashMap<E,Object>(initialCapacity, loadFactor);     }    
 public HashSet(int initialCapacity)     {    
     map = new HashMap<E,Object>(initialCapacity);     }    
 HashSet(int initialCapacity, float loadFactor, boolean dummy)     {    
     map = new LinkedHashMap<E,Object>(initialCapacity , loadFactor);    }    
// 调用 map 的 keySet 来返回所有的 key        public Iterator<E> iterator()    
 {    
     return map.keySet().iterator();     }

// 调用 HashMap 的 size() 方法返回 Entry 的数量,就得到该 Set 里元素的个数   
 public int size()     {    
     return map.size();     }    
 // 调用 HashMap 的 isEmpty() 判断该 HashSet 是否为空,    // 当 HashMap 为空时,对应的 HashSet 也为空    public boolean isEmpty()     {    
     return map.isEmpty();     }    
 // 调用 HashMap 的 containsKey 判断是否包含指定 key     // HashSet 的所有元素就是通过 HashMap 的 key 来保存的    public boolean contains(Object o)     {    
     return map.containsKey(o);     }    
// 将指定元素放入 HashSet 中,也就是将该元素作为 key 放入 HashMap     public boolean add(E e)     {    
     return map.put(e, PRESENT) == null;     }    
// 调用 HashMap 的 remove 方法删除指定 Entry,也就删除了 HashSet 中对应的元素   
 public boolean remove(Object o)     {    
     return map.remove(o)==PRESENT;     }    
 // 调用 Map 的 clear 方法清空所有 Entry,也就清空了 HashSet 中所有元素   
 public void clear()     {    
     map.clear();     }     ...    }    
 
由上面源程序可以看出,HashSet 的实现其实只是封装了一个 HashMap 对象来存储所有的集合元素,所有放入 HashSet 中的集合元素实际上由 HashMap 的 key 来保存,而 HashMap 的 value 则存储了一个 PRESENT,它是一个静态的 Object 对象。  
HashSet 的绝大部分方法都是通过调用 HashMap 的方法来实现的,因此 HashSet 和 HashMap 两个集合在实现本质上是相同的。

二.HashSet<E>对象 
HashSet<E>创建的对象称为集合: 
HashSet<string> s= HashSet<string>; 
那么s就是一个可以存储 string 类型数据的集合,s 可以调用add(String  s)方法将string类型的数据添加到集合中。添加到集合中的数据称为集合的元素。集合不允许有相同的元素,也就是说,如果b已经是集合中的元素,那么在执行set.add(b)操作是无效的。 三.HashSet<E>中的方法详解 
① public boolean add(E o) —— 向集合添加参数指定的元素。(如果此集合中还
不包含指定元素,则添加指定元素。) 
      参数: 
o - 将添加到此集合中的元素。  返回: 
如果该集合还不包含指定元素,则返回 true。 
 
② public void clear() ——清空集合,使集合不含有任何元素。 
③ public boolean contains(Object o) —— 判断参数指定的数据是否属于集合。() 
参数:  
o - 其在此集合中的存在已得到测试的元素。  
返回:  
如果此集合不包含指定元素,则返回 true。 
④ public boolean isEmpty()—— 判断集合是否为空。 
返回:  
如果此集合不包含任何元素,则返回 true。 
⑤ public boolean remove(Object o) ——集合删除参数指定的元素。 
参数:  
o - 如果存在于此集合中则需要将其移除的对象。  
返回:  
如果集合包含指定元素,则返回 true。 
⑥ public int size () —— 返回集合中元素的个数。 
返回:  
此集合中的元素的数量(集合的容量)。 
⑦ Object [ ] toArray() —— 将集合元素存放到数组中,并返回这个数组。 
⑧ boolean containsAll (HashSet set) —— 判断当前集合是否包含参数指定的集合。 
⑨ public Object clone () —— 得到当前集合的一个克隆对象,该对象中元素的改
变不会影响到当前集合中的元素,反之亦然。 返回:  
此集合的浅表复制。 
 
四.代码:

import java.util.HashSet;   
class Student{       String name;       int score;   
    Student(String name, int score){           this.name = name;           this.score = score;       }   }   
public class TestHashSet{      
    public static void main(String[] args) {   
        Student zh = new Student("张三",77);           Student li = new Student("李四",68);           Student wa = new Student("王五",67);              
        HashSet<Student> set = new HashSet<Student>();           HashSet<Student> subset = new HashSet<Student>();            
        System.out.println("Before add(zh):"+set.add(zh));             set.add(zh);  
        System.out.println("After  add(zh):"+set.add(zh));   //add方法的实现         set.add(wa);           set.add(li);              
        subset.add(wa);           subset.add(li);   
        System.out.println("Is subset empty?  "+subset.isEmpty()); //isempty方法的实现          
        if (set.contains(wa)){   
            System.out.println("集合set中含有:"+wa.name);  //contains方法的实现         }          
        if(set.containsAll(subset)){   
            System.out.println("集合set包含集合subset");           }            
        int number = subset.size();               //size方法的实现         System.out.println("集合subset中有"+number+"个元素:");            
        Object s[] = subset.toArray();            //toArray 方法的实现

for(int i=0; i<s.length; i++){   
            System.out.printf("姓名:%s,分数:%d\n", ((Student)s[i]).name,((Student)s[i]).score);           }          
        subset.remove(wa);                       //remove方法的实现         System.out.println("After implement remove on subset");  
        System.out.println("集合subset中有"+subset.size()+"个元素:");          
        Object a[] = subset.toArray();                  
        for(int i=0; i<a.length; i++){   
            System.out.printf("姓名:%s,分数:%d\n", ((Student)a[i]).name,((Student)a[i]).score);           }       }   } 
五.运行结果  
Before add(zh):true After  add(zh):false Is subset empty?  false 集合set中含有:王五 集合set包含集合subset 集合subset中有2个元素: 姓名:李四,分数:68 姓名:王五,分数:67 
After implement remove on subset 集合subset中有1个元素: 姓名:李四,分数:68

Java中HashSet的解读的更多相关文章

  1. Java中HashSet和HashMap

    Set中存储元素为什么不重复(即使hashCode相同)? HashSet中存放自定义类型元素时候,需要重写对象中的hashCode方法和equals方法, HashSet中存放自定义类型元素时候,需 ...

  2. Java中HashSet的重复性与判等运算重载

    目录 还有一个故事--(平行世界篇) 还有一个美丽的梦幻家园:java.util 并且还有一个善战的达拉崩巴:HashSet 还有另外一个故事(不是虚假传说) 还有一对涂满毒药的夺命双匕:equals ...

  3. Java中HashSet,HashMap和HashTable的区别

    HashMap.HashSet.HashTable之间的区别是Java程序员的一个常见面试题目,在此仅以此博客记录,并深入源代码进行分析: 在分析之前,先将其区别列于下面 1:HashSet底层采用的 ...

  4. java中HashSet详解(转)

    HashSet 的实现 对于 HashSet 而言,它是基于 HashMap 实现的,HashSet 底层采用 HashMap 来保存所有元素,因此 HashSet 的实现比较简单,查看 HashSe ...

  5. java中HashSet详解

    HashSet 的实现 对于 HashSet 而言,它是基于 HashMap 实现的,HashSet 底层采用 HashMap 来保存所有元素,因此 HashSet 的实现比较简单,查看 HashSe ...

  6. java集合(4)- java中HashSet详解

    HashSet 的实现 对于 HashSet 而言,它是基于 HashMap 实现的,HashSet 底层采用 HashMap 来保存所有元素,因此 HashSet 的实现比较简单,查看 HashSe ...

  7. java中hashSet原理

    转自: http://blog.csdn.net/guoweimelon/article/details/50804799 HashSet是JavaMap类型的集合类中最常使用的,本文基于Java1. ...

  8. java中HashSet实现(转)

    hashset底层的数据结构是hash表,hash表实现方式采用数组+链表,数组类型为HashNode,每个数组元素为链表的头指针,链表中存储经过hash函数散列后冲突的元素,数组的长度为26 has ...

  9. java中HashSet对象内的元素的hashCode值不能变化

    因为不管是HashMap(或HashTable,还是HashSet),key值是以hashCode值存进去的,加入key值变了,将无法从集合内删除对象,导致内存溢出.

随机推荐

  1. css细节复习笔记——内边距、边框和外边距

    一个元素的内边距.边框和外边距属性会影响着整个文档如何布局,更重要的是,它们会严重影响给定元素的外观. 高度和宽度 这两个属性不能应用到行内非替换元素,其高度和宽度由链接的内容确定,而不是由创作人员确 ...

  2. k8s service

    Service也是k8s的最小操作单元,是真实应用服务的抽象 Service通常用来将浮动的资源与后端真实提供服务的容器进行关联 Service对外表现为一个单一的访问接口,外部不需要了解后端的规模与 ...

  3. Kubernetes 集群安装部署

    etcd集群配置 master节点配置 1.安装kubernetes etcd [root@k8s ~]# yum -y install kubernetes-master etcd 2.配置 etc ...

  4. django系列8.3.2--django中间件实现登录验证(2) 个人构想逻辑

    middleware.py from django.utils.deprecation import MiddlewareMixin from django.shortcuts import rend ...

  5. Generating an arbitrary digit password dictionary

    原理说明:以增量方式从开始到结束! 实现方法:CMD命令 特点:纯数字 语法: FOR /L %variable IN (start,step,end) DO command [command-par ...

  6. grunt 常用插件

    grunt-contrib-uglify:代码压缩 grunt-contrib-jshint:检查js拼写错误 csslint:检查css语法错误

  7. Nginx采用yum安装-Carr

    (1)使用yum安装nginx需要包括Nginx的库,安装Nginx的库 #rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx- ...

  8. python有哪些比较隐藏的知识点?

    一.复用小整数以及小字符串 在Python语言中,设计者在优化Python语言时,为了提高Python的运行效率,所以就将一些小整数保存在系统表,没有释放回收(正常情况下,当Python中一个对象没有 ...

  9. 1. C++11保证稳定性与兼容性

    1.1 __func__预定义标识符 在c99中,__func__基本功能是返回所在函数的名字,c++11中允许使用在类或结构体中. #include <iostream> using n ...

  10. 再也不怕aop的原理了

    1 aop是什么 java的核心思想是面向对象,aop是面向切面编程.是对面向对象的一个补充,简单通俗的理解下aop,假设我们上楼梯,我的目标是三楼,我直接朝我的三楼直接过去,但是我可以在二楼的时候去 ...