一些Java集合面试题

1.总体讲一下Java集合

Java集合主要是由两大接口派生而来。一个是Collection接口,主要用于存放单一元素,主要分成Set,List和Queue三大类;另一个是Map接口,主要用于存放键值对元素,主要实现类就是HashMap、LinkedHashMap、TreeMap。

2.List有哪些具体的实现类?各个数据结构是怎样的?

List主要是ArrayList和LinkedList,ArrayList底层是object数组,ArrayList基于动态数组实现,它允许通过索引快速访问元素,查询时间复杂度:O(1),如果查询的是索引位置的元素。插入元素效率比较慢,因为涉及到前后元素的位移。LinkedList底层是双向链表,双向链表在首尾插入删除元素都比较方便,时间复杂度是O(1),检索效率比较慢,因为要从首尾将指针移动到相应的位置,时间复杂度是O(n)。

3.介绍CopyOnWriteArrayList

底层实现采用了写入时拷贝的思想,增删改操作会将底层数组拷贝一份,更改操作在新数组上执行,实现了并发读,读写分离。

写操作里面利用synchronized保证写写互斥,读操作foreach没有加锁,适合读多写少的场景

get/迭代器弱一致性:对于读线程,会出现写线程操作结束后,读线程还是读取到写之前的数组

相关推荐
lee_curry8 小时前
第四章 jvm中的垃圾回收器
java·jvm·垃圾收集器
九转成圣9 小时前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json
SmartRadio9 小时前
ESP32-S3 双模式切换实现:兼顾手机_路由器连接与WiFi长距离通信
开发语言·网络·智能手机·esp32·长距离wifi
laowangpython10 小时前
Rust 入门:GitHub 热门内存安全编程语言
开发语言·其他·rust·github
我叫汪枫10 小时前
在后台管理系统中,如何递归和选择保留的思路来过滤菜单
开发语言·javascript·node.js·ecmascript
_.Switch10 小时前
东方财富股票数据JS逆向:secids字段和AES加密实战
开发语言·前端·javascript·网络·爬虫·python·ecmascript
软件技术NINI10 小时前
webkit简介及工作流程
开发语言·前端·javascript·udp·ecmascript·webkit·yarn
Brendan_00110 小时前
JavaScript的Stomp.over
开发语言·javascript·ecmascript
念23410 小时前
f5 shape分析
开发语言·javascript·ecmascript
苍穹之跃10 小时前
某量JS逆向
开发语言·javascript·ecmascript