2021-07-22-HashSet集合概述和特点


layout: post
#标题配置
title: HashSet集合概述和特点
#时间配置
date: 2021-07-22 18:00:00 +0800
#目录配置
categories: 数据结构
#标签配置
tag: 学习笔记

  • content
    {:toc}

HashSet集合概述和特点

HashSet集合特点

(1)底层数据结构是哈希表

(2)不能保证存储和取出的顺序完全一致

(3)没有带索引的方法,所以不能使用普通for循环遍历

(4)由于是Set集合,所以元素唯一

哈希值

哈希值是JDK根据对象的地址或者属性值,算出来的int类型的整数

Object类中有一个方法可以获取对象的哈希值
public int hashCode():根据对象的地址值计算出来的哈希值

对象的哈希值特点
(1)如果没有重写hashCode方法,那么是根据对象的地址值计算出来的哈希值
同一个对象多次调用hashCode() 方法返回的哈希值是相同的
不同对象的哈希值是不一样的
(2)如果有重写了hashCode方法,一般都是同规格对象的属性值计算出哈希值
如果不同的对象属性值是一样的,那么计算出来的哈希值也是一样的

常见数据结构之哈希表

哈希表

JDK8之前,底层采用数组+链表实现
JDK8以后,底层进行了优化,由数组+链表+红黑树实现

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

拾光1024

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值