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 能保证复合操作的原子性吗

相关推荐
做个文艺程序员4 分钟前
Spring AI + Qwen3.5 实现多步 Agent:从工具调用到自主任务拆解的踩坑全记录
java·人工智能·spring
gentle_ice11 分钟前
初入社会的我该何去何从
java
企鹅的蚂蚁24 分钟前
【ESP32-S3开发踩坑】C++野指针引发的LoadProhibited死机与CMake依赖锁死排查
开发语言·c++
XiaoQiao66699927 分钟前
python 简单题目练手【详解版】【1】
开发语言·python
Kiling_070427 分钟前
Java多态、final与抽象类:面向对象编程进阶指南
java·开发语言
智算菩萨33 分钟前
【Python图像处理】2 数字图像基础与Python图像表示
开发语言·图像处理·python
better_liang1 小时前
每日Java面试场景题知识点之-MySQL索引
java·数据库·mysql·性能优化·索引
Aktx20FNz1 小时前
一文学习 Spring AOP 源码全过程
java·学习·spring
Nyarlathotep01131 小时前
ThreadLocal
java·后端
Jasmine_llq1 小时前
《B3840 [GESP202306 二级] 找素数》
开发语言·c++·试除法·顺序输入输出算法·素数判定算法·枚举遍历算法·布尔标记算法