一些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/迭代器弱一致性:对于读线程,会出现写线程操作结束后,读线程还是读取到写之前的数组

相关推荐
乐悠小码1 分钟前
数据结构------队列(Java语言描述)
java·开发语言·数据结构·链表·队列
史努比.3 分钟前
Pod控制器
java·开发语言
2的n次方_6 分钟前
二维费用背包问题
java·算法·动态规划
皮皮林5516 分钟前
警惕!List.of() vs Arrays.asList():这些隐藏差异可能让你的代码崩溃!
java
莳光.6 分钟前
122、java的LambdaQueryWapper的条件拼接实现数据sql中and (column1 =1 or column1 is null)
java·mybatis
程序猿麦小七11 分钟前
基于springboot的景区网页设计与实现
java·spring boot·后端·旅游·景区
敲敲敲-敲代码12 分钟前
游戏设计:推箱子【easyx图形界面/c语言】
c语言·开发语言·游戏
weisian15118 分钟前
认证鉴权框架SpringSecurity-2--重点组件和过滤器链篇
java·安全
蓝田~19 分钟前
SpringBoot-自定义注解,拦截器
java·spring boot·后端
ROC_bird..21 分钟前
STL - vector的使用和模拟实现
开发语言·c++