每天一个面经系列--面经31:面试官问我看过哪些源码

本文详细探讨了HashMap的内部实现原理,包括其在不同场景下如何进行rehash和扩容操作,分析了高并发环境下出现死循环的原因,并对比了HashMap与HashTable、ConcurrentHashMap的差异。同时,文章还介绍了ConcurrentSkipListMap的工作机制及其与ConcurrentHashMap的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、你看过哪些源码吗? 

集合类、JUC、String、StringBuffer、StringBuilder、Spring

2、那你能讲讲HashMap的实现原理吗? 

相关好博客:https://segmentfault.com/a/1190000012926722

https://zhuanlan.zhihu.com/p/21673805

3、HashMap什么时候会进行rehash?

4、HashMap什么时候会进行扩容? 

5、那HashMap的初始容量设置成多少比较合适呢? 

6、结合源码说说HashMap在高并发场景中为什么会出现死循环? 

7、JDK1.8中对HashMap做了哪些性能优化? 

8、HashMap和HashTable有何不同? 

9、HashMap 和 ConcurrentHashMap 的区别? 

10、ConcurrentHashMap和LinkedHashMap有什么区别? 

11、为什么ConcurrentHashMap中的链表转红黑树的阀值是8? 

12、什么是ConcurrentSkipListMap?他和ConcurrentHashMap有什么区别? 

13、还看过其他的源码吗?Spring的源码有了解吗? 

14、SpringBoot的源码呢?知道starter是怎么实现的吗?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值