常见面试题整理1

面试题整理1

list 和set

相同点:都是继承Collection接口
不同点:
1.list 元素存放有顺序,元素可重复
set 元素存放无顺序,元素不可重复
2.list 支持for循环,也可以用迭代器
set 只能用迭代器,因为它是无序的,无法通过下标获取元素
3.list和数组相似,查找元素效率高,插入删除元素效率低,插入删除元素位置会发生改变
set查找元素效率低,插入删除元素效率高,插入删除元素位置不会改变

hashMap是线程安全的吗

不是线程安全的

比如线程A和线程B同时进行hashMap插入操作,两个线程插入的数据计算的hash值相同,并且该位置当前为空,这是线程A先进行if判断符合条件,当A进入if后Cpu将资源调度给线程B使用,这时B也进入到if语句中,当A向该位置插入数据后,轮到B也向该位置添加数据,这时就会覆盖掉A的数据,发生了线程不安全现象。
在这里插入图片描述

hashMap 扩容过程

当向容器添加元素时,会先判断当前容器的元素个数,如果大于等于阈值,即当前数组的长度乘以加载因子的值得时候,就会自动扩容了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值