浅谈HashSet

HashSet结构图
HashSet.png
HashSet主要方法
  • public boolean add(E e)
  • public boolean remove(Object o)
HashSet方法解读

public boolean add(E e)源码:

//hashset 利用的是hashmap,所以每次放入的value都是PRESENT
private static final Object PRESENT = new Object();
public boolean add(E e) {
        //可以看到,hashset利用的是hashmap的key,把它对应的值放入到key里,value放入的都是固定的值
        return map.put(e, PRESENT)==null;
    }

public boolean remove(Object o)源码:

 public boolean remove(Object o) {
        //hashmap的删除最终会返回删除对象的value值,hashset通过判断这个value值是不是等于PRESENT来判断是否删除成功
        return map.remove(o)==PRESENT;
    }
HashSet遍历方式
 // one
for (Object o : set) {
    System.out.println(o);
 }
// two
 Iterator iterator = set.iterator();
 while (iterator.hasNext()) {
       System.out.println(iterator.next());
  }
HashSet其他特性介绍
  • hashset是由hashmap构成的,主要利用的就是hashmap的key来保存相应的值
  • hashset的值是不可以重复的,主要性质是由hashmap决定的,hashmap重复的key算一个key,hashset是可以放入为空的元素的。
  • hashset也不是线程安全的,多线程环境下操作也是有问题的。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、基本数据类型 注释 单行注释:// 区域注释:/* */ 文档注释:/** */ 数值 对于byte类型而言...
    龙猫小爷阅读 4,291评论 0 16
  • 实际上,HashSet 和 HashMap 之间有很多相似之处,对于 HashSet 而言,系统采用 Hash 算...
    曹振华阅读 2,527评论 1 37
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,778评论 18 399
  • java笔记第一天 == 和 equals ==比较的比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量...
    jmychou阅读 1,525评论 0 3
  • 昨天的克罗地亚登场唤醒了很多人对前南足球的记忆,在欧洲杯扩军的大背景下,除了克罗地亚,斯洛文尼亚、马其顿、波黑、塞...
    流殇夕水阅读 300评论 0 0