ArraySet 源码解析

1、简述
  • 我们都知道 HashSet,它属于 java.util 包下,但是很多人可能对 ArraySet 并不是很熟悉,通俗来说 ArraySet 属于 android.util 包下,是用于 Android 平台某些情况替换 HashSet 的数据结构。
  • 使用限定:minSdkVersion 必须大于等于 23(Android 6.0)。
2、归纳
  • 实现了 Collection 和 Set 接口。
  • 底层采用两个一维数组,第一个数组是整型数组,且有序,存储 key 对应的 hash 值,第二个数组存储 value 值。
  • 每次插入时,根据 key 的哈希值,利用二分查找,去寻找 key 在整型数组中的下标位置,如果出现了 hash 冲突,则从需要从目标点向两头遍历,找到正确的 index。
  • 扩容机制,如果容量小于4,则扩容到4,如果容量大于等于4小于8,则扩容到8,如果容量大于等于8,则扩容到当前容量加当前容量的一半。
  • 缩容机制,如果存储 hash 值的数组长度大于等于8,且集合长度少于当前空间的1/3,则进行收缩操作,避免浪费空间。
  • ArraySet 的操作单线安全,多线程不安全。
  • 1000 以内元素性能 ArraySet 相对 HashSet 更高。
3、分析
  • ArraySet 的源码跟 ArrayMap 源码基本上相差不大,所以在这就不做单独分析了,如果你掌握了 ArrayMap 源码,基本上就掌握了 ArraySet 源码。
  • ArrayMap 的源码在上篇已经分析了,感兴趣的同学可以查看对应文章。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值