关于面试中的HashMap

底层结构:
哈希表
JDK7:数组+链表、Entry[ ]、table直接初始化容量为16
JDK8:数组+链表+红黑树、Node[ ]、table没有初始化,在第一次添加元素时才初始化
特点:
1、允许null键null值。2、不保证键的顺序
hashmap线程不安全,可以使用JUC包中的ConcurrentHashMap解决
添加元素过程:
创建HashTable对象时,table数组没有初始化,只是加载因子loadFactor初始化0.75,如果是第一次添加元素(key元素要重写hashcode和equals),初始化容量为16,临界值为12,如果不是第一次添加,判断是否有元素,没有的话直接添加,有的话如果相等就覆盖,不相等的话如果是树的结构就根据树的特点解决,链表的结构就按链表特点解决。
每次添加元素,先判断 ++size > 临界值threshold,如果满足,进行2倍扩容,需要将所有元素重新计算存放,当链表的节点数 >= 8 && table的容量 >= 64 ,链表结构会转换成树结构

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值