HashMap源码分析

static final int DEFAULT_INITIAL_CAPACITY = 16;//初始化值大小为16
static final int MAXIMUM_CAPACITY = 1 << 30;//最大值为2^30
static final float DEFAULT_LOAD_FACTOR = 0.75f;//负载因子,当数组的容量超过当前默认大小的0.75的时候就会进加倍,也就是说当数组添加到16*0.75=12时,数组扩大一倍
关于线程不安全:
当多个线程同时操作同一个数组位置的时候,后来的写入的会覆盖前面写入的数据,造成前面的数据写入丢失
Concurrenthashmap是线程安全的,因为其中用到了分段锁技术,就是数据存储区分为一个个桶,每一个桶都用锁,而不是像hashtable把整张表都锁起来。这样效率很低,而分段锁技术只锁住部分数据,其他的数据不受影响

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值