- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
2025年高频java集合必会面试试题及答案
1.请说明ArrayList和LinkedList的核心差异及各自适用场景?
ArrayList基于动态数组实现,内部维护Object[]elementData数组,默认初始容量10。新增元素时若容量不足会触发扩容,扩容后新容量为原容量的1.5倍(oldCapacity+(oldCapacity1))。其随机访问时间复杂度O(1)(通过索引直接计算内存地址),但中间插入/删除需移动后续元素,时间复杂度O(n)。
LinkedList基于双向链表实现,每个节点(Node)包含prev、next指针和item值。插入/删除操作只需调整相邻节点指针,时间复杂度O(1)(若已知插入位置),但随机访问需从头/尾遍历,时间复杂度O(n)。此外,LinkedList实现了Deque接口,可作为队列/双端队列使用。
适用场景:ArrayList适合高频随机访问、低频增删的场景(如数据展示列表);LinkedList适合高频增删(尤其首尾操作)、需要队列特性的场景(如任务队列)。
2.HashMap在JDK8中的底层结构相比JDK7有哪些主要优化?
JDK7的HashMap采用数组+链表结构,哈希冲突时通过链表解决,最坏情况下(所有元素哈希到同一位置)查找时间复杂度退化为O(n)。
JDK8优化为数组+链表+红黑树结构:当链表长度≥8且数组长度≥64时,链表转换为红黑树(treeifyBin),查找时间复杂度降至O(logn);当红黑树节点数≤6时,退化为链表(untreeify)。此优化解决了高冲突场景下的性能问题。
其他优化包括:哈希计算简化(hash()方法仅高16位异或低16位,JDK7还包含4次扰动);扩容时采用尾插法(JDK7为头插法,多线程下可能导致循环链表);resize()方法在JDK8中通过判断(e.hasholdCap)是否为0决定元素迁移位置,避免重新计算哈希。
3.为什么HashMap线程不安全?多线程环境下可能出现哪些问题?
HashMap的线程不安全体现在:
(1)多线程扩容导致的数据丢失或循环链表(JDK7):JDK7扩容时采用头插法迁移元素,若两个线程同时执行resize,可能导致链表节点的next指针形成环,后续查找时进入死循环;JDK8虽改为尾插法,但多线程put仍可能导致数据覆盖(两个线程同时计算出相同插入位置,后写入的覆盖先写入的值)。
(2)size计数不准确:modCount变量未保证原子性,多线程并发修改时可能导致size值错误。
(3)迭代器的fail-fast机制失效:迭代过程中若其他线程修改集合,会抛出ConcurrentModificationException,但多线程环境下无法保证迭代器的一致性。
4.如何实现一个线程安全的HashMap?ConcurrentHashMap在JDK8中的线程安全机制是什么?
线程安全的HashMap实现方案:
(1)使用Hashtable:所有方法用synchronized修饰,锁粒度为整个哈希表,并发效率低。
(2)使用Collections.synchronizedMap():返回SynchronizedMap包装类,内部通过mutex锁实现同步,锁粒度仍为整个对象。
(3)使用ConcurrentHashMap:JDK7采用分段锁(Segment数组,每个Segment继承ReentrantLock,默认16个分段,支持16线程并发写);JDK8放弃分段锁,采用CAS+synchronized实现:
节点级锁:synchronized锁定链表头节点(或红黑树根节点),仅影响当前桶的操作,锁粒度更细。
CAS操作:插入节点时先通过CAS尝试添加,失败后再加锁,减少锁竞争。
扩容标记:当节点状态为MOVED(-1)时,表示正在扩容,当前线程协助迁移数据(helpTransfer),提升扩容并发度。
5.解释HashSet的底层实现,为什么添加重复元素会返回false?
HashSet内部基于HashMap实现,存储的元素作为HashMap的key,value统一为PRESENT(newObject())。添加元素时调用HashMap的put()方法:若key已存在,put()返回旧value(非null),因此HashSet的add()方法返回false;若key不存在,put()返回null,add()返回true。
由于HashMap的key不允许重复(通过equals()和hashCode()判断),因此HashSet的元素具有唯一性。需注意:若存储对象的hashCode()或equals()方法被重写,修改对象属性可能导致其无法被正确查找或删除(例如,对象存入HashSe
您可能关注的文档
- (2025年)(合集)环境保护法试题及答案.docx
- (2025年)[工会考试试题题库及答案解析].docx
- (2025年)安徽省亳州市辅警招聘考试试题库附完整答案.docx
- (2025年)安全生产法律法规考试题型及答案.docx
- (2025年)巴音郭楞蒙古自治州尉犁县辅警考试公安基础知识考试真题库及答案.docx
- (2025年)拜城县公共基础辅警考试笔试题库及答案.docx
- (2025年)病理学与病理生理学试题及答案.docx
- (2025年)采油地质工初级测试题与参考答案.docx
- (2025年)楚雄辅警招聘考试试题库附完整答案.docx
- (2025年)恩施土家族苗族自治州来凤县辅警考试真题及答案.docx
最近下载
- 2026年江苏省高二生物学业水平合格考调研试卷(含答案详解).pdf VIP
- 《海报设计》课件——第1章 海报招贴设计原理.ppt VIP
- 2025年山东省菏泽市牡丹区二模数学试题.doc VIP
- 固定支架推力计算.xls
- 消防队安全形势分析会.pdf VIP
- 电大1425《调剂学(本)》开放大学期末考试历届试题2025年1月(含答案).docx VIP
- 04CJ01-1 变形缝建筑构造(一).pdf VIP
- 2020 ACLS-PC-SA课前自我测试试题及答案.doc
- 煤炭公司成本管理问题研究本科毕业论文.doc VIP
- 2026年宁夏贺兰工业园区管委会工作人员社会化公开招聘备考题库参考答案详解.docx VIP
原创力文档


文档评论(0)