Java八股文-List集合

集合的底层是否加锁也就代表是否线程安全

(一)List集合

一、数组

array[1]是如何通过索引找到堆内存中对应的这块数据的呢?

(1)数组如何获取其他元素的地址值
(2)为什么数组的索引是从0开始的,不可以从1开始吗
(3)操作数组的时间复杂度
①查找
  1. 根据索引查询
  2. 未知索引查询
    情况一:

    因为要想在未知索引且未进行排序的情况下去查找数组内的元素就需要去遍历整个数组,所以它的时间复杂度就为O(n)
    情况二:

    数组在经过排序以后就可以使用二分查找法来查找元素,时间复杂度就为O(logn)
②插入、删除
(3)总结

二、ArrayList源码分析

关键方法指的是添加方法与扩容方法

(1)成员变量
(2)构造方法

collection对象是所有单列集合的父接口

(3)关键方法

测试方法:

①第一次添加数据(也就是数组初始化的情况)

ensureCapacityInternal方法用于确保elementData数组的内部容量,calculateCapacity方法用于计算容量,ensureExplicitCapacity方法用于确保明确的容量

②第二至十次添加数据(也就是数组不扩容的情况)

在第二至第十次添加数据时都是直接向数组中插入数据,不需要进行数组扩容

③第十一次添加数据(也就是数组扩容的情况)

三、ArrayList的底层原理及构造函数

(1)底层原理
(2)构造函数

四、如何实现数组和List之间的转换


(1)数组转List集合

运行测试方法:

查看asList方法的源码:

数组通过asList方法传入后在内部创建了一个ArrayList集合,但是它并不是我们平时见到的ArrayList,而是当前Arrays类的一个内部类,并且调用了它的构造方法,将传入的数组赋值给a数组。

说明在该方法中只涉及到了对象的引用,并没有创建新对象,他们两个指向的是同一个地址值。

(2)List集合转数组

运行测试方法:

查看toArray方法的源码:

可以看到在arraycopy方法中将传入的a集合拷贝给了一个新的elementData数组,也就是复制数据到一个新的数组中,所以他们两个是不同的对象。

五、链表

(1)单项链表


①单向链表的时间复杂度分析
  1. 查询操作
  2. 新增\删除操作
(2)双向链表
①双向链表的时间复杂度分析
(3)总结

六、ArrayList和LinkedList的区别



可以使用collections工具类并调用synchronizedList方法来包装集合,这样得到的List集合就是线程安全的,因为它在底层为该集合加上了一个锁,但是性能会下降一些。

总结:

相关推荐
麦兜*40 分钟前
Spring Boot 企业级动态权限全栈深度解决方案,设计思路,代码分析
java·spring boot·后端·spring·spring cloud·性能优化·springcloud
序属秋秋秋41 分钟前
《C++初阶之内存管理》【内存分布 + operator new/delete + 定位new】
开发语言·c++·笔记·学习
ruan1145142 小时前
MySQL4种隔离级别
java·开发语言·mysql
quant_19863 小时前
R语言如何接入实时行情接口
开发语言·经验分享·笔记·python·websocket·金融·r语言
Hellyc6 小时前
基于模板设计模式开发优惠券推送功能以及对过期优惠卷进行定时清理
java·数据库·设计模式·rocketmq
lifallen6 小时前
Paimon LSM Tree Compaction 策略
java·大数据·数据结构·数据库·算法·lsm-tree
hdsoft_huge6 小时前
SpringBoot 与 JPA 整合全解析:架构优势、应用场景、集成指南与最佳实践
java·spring boot·架构
百锦再7 小时前
详细解析 .NET 依赖注入的三种生命周期模式
java·开发语言·.net·di·注入·模式·依赖
程序员的世界你不懂7 小时前
基于Java+Maven+Testng+Selenium+Log4j+Allure+Jenkins搭建一个WebUI自动化框架(2)对框架加入业务逻辑层
java·selenium·maven
风吹落叶花飘荡7 小时前
2025 Next.js项目提前编译并在服务器
服务器·开发语言·javascript