ConcurrentHashmap面试【高频】

  1. ConcurrentHashmap的key,value是否可以为null?为什么?
    不行,如果key或者value为null会抛出空指针异常。
    原因:null具有二义性问题,没办法确定存储值本身是null,还是说值不存在(因为默认是null)->就理解为多线程会不安全就行,HashMap可以是因为单线程
  2. 1.8的扩容允许多线程吗?
    可以。
    当put的时候,发现当前node hash值是-1,则表示当前的节点正在扩容,则会触发协助扩容机制:
    扩容就是搬迁Node,就是会维护一个transferIndex变量,来的线程死循环cas争抢下标,如果下标已经分配完了,如果cas抢到了要搬运的下标,就去帮忙搬就行

其中几个数据:

  • 参与搬迁的线程数不会多余CPU数
  • 每个线程至少负责16个槽位的搬迁
    • 如果ConcurrentHashMap只有16个槽,只会有一个线程来负责搬
    • 如果大于16,由CPU来进行分配,使用CAS来争抢下标。结果:至少1个线程,最多2个线程来负责(32的情况)

Java8 链表转红黑树(8)和红黑树链表(6)为什么是8和6?

红黑树所占的空间虽然是链表中Node所占空间的两倍,虽然红黑树的**查找效率为o(logN),要优化链表的o(N),**但是当链表的长度比较小的时候,即使全部遍历,时间复杂度也不会太高。

->所以需要寻找一个时间和空间的平衡,即在链表长度达到一个阈值之后再转换为红黑树。

  • **之所以是8,**这个是研究者研究哈希碰撞的泊松分布,发现逐渐降低了->基本上不可能碰撞,如果发生了8次,这个时候说明由于元素本身和hash函数的原因
  • 链表的阈值是6 ,主要是因为如果也将阈值设置为8,那么当hash碰撞在8时,会发生链表和红黑树的不停相互激荡转换,白白浪费资源。中间有个差值7可以防止链表和树之间的频繁转换
相关推荐
Chen-Edward10 分钟前
有了Spring为什么还有要Spring Boot?
java·spring boot·spring
陈小桔1 小时前
idea中重新加载所有maven项目失败,但maven compile成功
java·maven
小学鸡!1 小时前
Spring Boot实现日志链路追踪
java·spring boot·后端
xiaogg36781 小时前
阿里云k8s1.33部署yaml和dockerfile配置文件
java·linux·kubernetes
逆光的July2 小时前
Hikari连接池
java
微风粼粼2 小时前
eclipse 导入javaweb项目,以及配置教程(傻瓜式教学)
java·ide·eclipse
番茄Salad2 小时前
Spring Boot临时解决循环依赖注入问题
java·spring boot·spring cloud
天若有情6732 小时前
Spring MVC文件上传与下载全面详解:从原理到实战
java·spring·mvc·springmvc·javaee·multipart
祈祷苍天赐我java之术2 小时前
Redis 数据类型与使用场景
java·开发语言·前端·redis·分布式·spring·bootstrap
Olrookie3 小时前
若依前后端分离版学习笔记(二十)——实现滑块验证码(vue3)
java·前端·笔记·后端·学习·vue·ruoyi