有序:元素保留其插入顺序。
灵活:允许重复,这样你就可以像老板的提醒一样重复。
最适合:快速随机访问和迭代。
缺点:插入和删除速度慢(因为元素需要移动)。
用例:当您需要频繁访问元素时,例如在媒体播放器中获取视频帧。
List<String> arrayList = new ArrayList<>(); arrayList.add("First"); arrayList.add("Second");
内存布局:ArrayList 维护一个连续的内存块,当超出其容量时,会调整大小 50% 或更多。 链接列表
支持:双向链表。
最适合:频繁插入和删除。
缺点:由于指针遍历,访问时间较慢。
用例:实现经常添加或删除歌曲的播放列表。
List<String> linkedList = new LinkedList<>(); linkedList.add("Node1"); linkedList.add("Node2");
内存布局:LinkedList 使用非连续内存,每个节点都指向其上一个和下一个节点。 CopyOnWriteArrayList
特殊用途:ArrayList 的线程安全变体。
工作原理:在每次修改时创建底层数组的新副本。
最适合:读取次数远多于写入的场景,例如缓存经常访问的数据。
缺点:占用内存且更新速度慢。
d. 矢量
旧版:在 Java 1.0 中引入。
线程安全:同步开销使其比现代替代方案慢。
有趣的事实:就像 List 的“爸爸笑话”一样,不是很有趣,但仍然存在。
List<String> arrayList = new ArrayList<>(); arrayList.add("First"); arrayList.add("Second");
List<String> linkedList = new LinkedList<>(); linkedList.add("Node1"); linkedList.add("Node2");
注意:这会返回一个固定大小的列表,因此您无法添加或删除元素。
List<String> list = new ArrayList<>();
不可变意味着没有 add()、remove() 或clear()——就像那个不让任何人碰他们的草坪的邻居一样。
List<String> list = Arrays.asList("A", "B", "C");
b. add(int 索引, E 元素)
在指定索引处插入一个元素,移动后续元素。
List<String> immutableList = List.of("X", "Y", "Z");
c.删除(int索引)
删除指定索引处的元素。
list.add("Element");
d.获取(int索引)
检索指定索引处的元素。
list.add(1, "Middle");
e. set(int 索引, E 元素)
用新元素替换指定位置的元素。
list.remove(0);
String element = list.get(2);
调整大小时:
list.set(1, "UpdatedElement");
b. LinkedList 内部结构 LinkedList 中的每个元素(节点)包含:
数据
指向下一个节点的指针
指向前一个节点的指针(双向链表)
遍历速度较慢,因为访问索引需要迭代节点。
图表 :
[Element1] [Element2] [Element3] [Null] ... [Null]
[Element1] [Element2] [Element3] [NewElement] [Null] ... [Null]
搜索算法 :
线性搜索:O(n) – 扫描每个元素。
二分查找:O(log n) – 需要一个排序列表。
List<String> arrayList = new ArrayList<>(); arrayList.add("First"); arrayList.add("Second");
List<String> linkedList = new LinkedList<>(); linkedList.add("Node1"); linkedList.add("Node2");
允许重复:绝对。
频繁访问操作:转到ArrayList。
频繁修改:转到LinkedList。
List<String> list = new ArrayList<>();
List<String> list = Arrays.asList("A", "B", "C");
List<String> immutableList = List.of("X", "Y", "Z");
list.add("Element");
使用泛型 :始终指定类型以避免 ClassCastException。
不要在循环中使用 new ArrayList :重用实例或正确管理以避免 OutOfMemoryError。
彻底理解List可以让你编写高效、可扩展、可读的Java程序。这就像在学习美食食谱之前掌握烹饪的基础知识一样,您将避免烧毁代码(和烤面包)。随意使用示例,创建自定义场景,并拥抱 List 的强大功能。请记住,经验丰富的开发人员知道每个元素都很重要,无论是在生活中还是在列表中。
现在继续前进,用你新掌握的列表来征服你的编码挑战,永远不要再让你的数组支配你!
以上是Java 列表终极指南:您需要了解的一切的详细内容。更多信息请关注PHP中文网其他相关文章!