为了账号安全,请及时绑定邮箱和手机立即绑定

Java知识点总结(Java容器-HashSet)

标签:
Java

原文链接:https://segmentfault.com/a/1190000015115133?utm_source=index-hottest

Java知识点总结(Java容器-HashSet)

@(Java知识点总结)[Java, Java容器, JavaCollection, JavaSet]

HashSet特点

HashSet按Hash算法来存取 查找集合中的元素

  1. HashSet具有很好的存取 查找的性能 从HashSet中查找某个对象时,首先调用对象的hashCode方法获取该对象的哈希码,然后根据哈希码找到相应的存储区域,最后取出该存储区域的每个元素与该元素进行equals方法比较,这样就不用遍历集合中所有元素就能查找到结果。

  2. HashSet不是同步的 也就是线程不安全,如果多个线程访问同一个Set集合,如果有2条或者2条以上线程同时修改了HashSet集合时,必须使用代码来保证其同步

  3. 元素值可以是null

  4. 不能保证元素的排列顺序,顺序有可能发生变化

手写HashSet

public class MyHashSet {
  HashMap map;  private static final Object PRESENT = new Object(); //把map里的value用一个常量来代替
  
  public MyHashSet(){
    map = new HashMap();
  }  public void add(Object obj) {
    map.put(obj , PRESENT);  //底层利用map,实现不可重复
  }  public int  size() {    return map .size();
  }  public static void main(String[] args) {
    MyHashSet set = new MyHashSet();
    set.add("1" );
    set.add("2" );
    set.add("3" );
    System.out.println(set.size());
  }
}


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消