孤尽班第17天 -- 集合与并发

Java 集合框架图

集合是数据结构的载体,其中包括接口、抽象类、并发包中的类、早起线程安全的类。

数据结构与时间复杂度

 略过

HashMap的基本概念

三个基本概念

table:存储所有节点数据的数组

slot:哈希槽。即table[i]这个位置

bucket:哈希桶。table[i]上所有元素形成的表或树的集合。

HashMap的主干是一个Entry数组。Entry是HashMap的基本组成单元,每一个Entry包含Node内部类。

当同一bucket的元素达到8个时,bucket会用红黑树存储元素。

HashMap如何设置初始容量

看一遍步骤能明白这是在做什么?但背后逻辑还需要再思考。真有必要这么复杂吗?

HashMap的哈希算法

剖析Collectors.toMap方法内部构造:

【强制】在使用java.util.stream.Collectors类的toMap()方法转发为Map集合时,一定要使用含有参数类型为BinaryOperator,参数名为mergeFunction的方法,否则当出现相同key值时会抛出IllegalStateException异常。

ArrayList的subList结果不可强转成ArrayList

ArrayList中的subList方法return的是一个SubList,它并不是ArrayList本身,也不是继承于ArrayList,所以强转会抛出ClassCastException异常。

在subList场景中

  • 高度注意对父集合元素的增加或删除,均会导致自列表的遍历
  • 增加、删除产生ConcurrentModificationException异常
  • 每次subList子列表的遍历、增加、删除都会调用checkForComodification()。 

credit:图片均来自孤尽老师的PPT。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值