2.Java集合常见面试题总结

ArrayList 可以添加 null 值吗?

ArrayList 的扩容机制

0 -- 10 --* 1.5

Set的3种实现类

  1. HashSet
  2. LinkHashSet(按照FIFO实现,底层是哈希表+双向链表)
  3. TreeSet(红黑树,自定义排序存储)

Queue的4个接口

quque

deque

priorityQueue

BlockingQueue

Map

HashMap 和 Hashtable 的区别

只需要知道HashTable是被淘汰了的CurrentHashMap

HashMap 和 HashSet 区别

HashSet直接调用的HashMap的方法(add = put,contains = containsKey等)

HashMap 和 TreeMap 区别

多了排序的功能

HashSet 如何检查重复?

HashMap

1、1.7和1.8的区别

3个:

红黑树

尾插法

扰动次数

2、hash的模为什么是2的幂次方?

  1. 越大越好
  2. 取模时 % == & 的前提是n为2的幂次方

3、扩容机制

  1. 超过64之后就不扩容了,改用链表和红黑树(每次扩容变为原来的2倍)
  2. 链表长度大于8时变为红黑树
  3. 扩容过程中,一个红黑树会被分为两半,预估每一半的长度,如果小于6就退化为链表

ConcurrentHashMap

1.7:

  1. 分段,默认16个段,把整个表分割为16个子Hash表,同时最多允许16个线程访问
  2. 拉链法,因此链表长度可能会很长。
  3. 使用悲观锁ReentrantLock

1.8:

  1. 舍弃分段的思想,每一个槽位都是一个独立的节点,并发量取决于有多少个槽位
  2. 红黑树,访问速度会变快
  3. 使用乐观锁CAS

ConcurrentHashMap迭代器是强一致性还是弱一致性?

为什么ConcurrentHashMap不能输入null?

什么是二义性混淆?

为什么单线程可以,多线程不行

ConcurrentHashMap 能保证复合操作的原子性吗

相关推荐
能工智人小辰8 分钟前
二刷 苍穹外卖day10(含bug修改)
java·开发语言
DKPT9 分钟前
Java设计模式之结构型模式(外观模式)介绍与说明
java·开发语言·笔记·学习·设计模式
缘来是庄11 分钟前
设计模式之外观模式
java·设计模式·外观模式
LL.。33 分钟前
同步回调和异步回调
开发语言·前端·javascript
0wioiw01 小时前
Python基础(吃洋葱小游戏)
开发语言·python·pygame
知其然亦知其所以然1 小时前
JVM社招面试题:队列和栈是什么?有什么区别?我在面试现场讲了个故事…
java·后端·面试
栗子~~1 小时前
Python实战- Milvus 向量库 使用相关方法demo
开发语言·python·milvus
狐凄1 小时前
Python实例题:基于 Flask 的在线聊天系统
开发语言·python
狐凄1 小时前
Python实例题:基于 Flask 的任务管理系统
开发语言·python
harmful_sheep1 小时前
Spring 为何需要三级缓存解决循环依赖,而不是二级缓存
java·spring·缓存