java集合(十) ---- LinkedList 类

目录

[十、LinkedList 类](#十、LinkedList 类)

[10.1 位置](#10.1 位置)

[10.2 特点](#10.2 特点)

[10.3 与 ArrayList 的区别](#10.3 与 ArrayList 的区别)

[10.4 构造方法](#10.4 构造方法)

[10.5 常用方法](#10.5 常用方法)


十、LinkedList 类

10.1 位置

LinkedList 类位于 java.util 包下

10.2 特点

  1. 是 List 接口的实现类
  2. 是 Deque 接口的实现类
  3. 底层使用双向循环链表结构

10.3 与 ArrayList 的区别

  1. ArrayList 类底层是数组,线性顺序存储。LinkedList 类底层是链表结构,非连续、非顺序存储
  2. ArrayList 类适合用于查询多的地方。LinkedList 类适合用于增删多的地方

10.4 构造方法

|----|------------------------------------------------|
| | public LinkedList() |
| 作用 | 创建一个空的 LinkedList 对象 |
| ||
| | public LinkedList(Collection<? extends E> c) |
| 作用 | 创建一个包含指定集合 c 的 LinkedList 对象 |

10.5 常用方法

|-----|-----------------------------------------------------------------------------------|
| | public void addFirst(E e) |
| | public boolean offerFirst(E e) |
| 方法名 | addFirst() offerFirst() |
| 作用 | 将指定元素插入到当前集合的开头 |
| ||
| | public void addLast(E e) |
| | public boolean offer(E e) |
| | public boolean offerLast(E e) |
| 方法名 | addLast() offer() offerLast() |
| 作用 | 将指定元素插入到当前集合的结尾 |
| 注意 | 此方法等效于 add(E e) |
| ||
| | public E getFirst() |
| | public E peekFirst() |
| 方法名 | getFirst() peekFirst() |
| 作用 | 获取当前集合的第一个元素 |
| ||
| | public E getLast() |
| | public E peekLast() |
| 方法名 | getLast() peekLast() |
| 作用 | 获取当前集合的最后一个元素 |
| ||
| | public E removeFirst() |
| | public E pollFirst() |
| 方法名 | removeFirst() pollFirst() |
| 作用 | 移除并返回当前集合的第一个元素 |
| ||
| | public E removeLast() |
| | public E pollLast() |
| 方法名 | removeLast() pollLast() |
| 作用 | 移除并返回当前集合的最后一个元素 |
| ||
| | public boolean removeFirstOccurrence(Object o) |
| 方法名 | removeFirstOccurrence() |
| 作用 | 从当前集合中移除第一次出现的指定元素 |
| ||
| | public boolean removeLastOccurrence(Object o) |
| 方法名 | boolean removeLastOccurrence() |
| 作用 | 从当前集合中移除最后一次出现的指定元素 |
| ||
| 说明一 | 其他常用方法参考 List 接口 |
| 说明二 | 链表不存在索引。但是可以调用 get(index) 来获取指定索引上的元素。这是因为 LinkedList 类在底层提供了一个 LisItr 内部类来提供索引 |


相关推荐
雨中飘荡的记忆7 分钟前
大流量下库存扣减的数据库瓶颈:Redis分片缓存解决方案
java·redis·后端
心之语歌3 小时前
基于注解+拦截器的API动态路由实现方案
java·后端
华仔啊4 小时前
Stream 代码越写越难看?JDFrame 让 Java 逻辑回归优雅
java·后端
ray_liang4 小时前
用六边形架构与整洁架构对比是伪命题?
java·架构
Ray Liang5 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
Java水解5 小时前
Java 中间件:Dubbo 服务降级(Mock 机制)
java·后端
SimonKing9 小时前
OpenCode AI辅助编程,不一样的编程思路,不写一行代码
java·后端·程序员
FastBean10 小时前
Jackson View Extension Spring Boot Starter
java·后端
Seven9711 小时前
剑指offer-79、最⻓不含重复字符的⼦字符串
java
皮皮林55120 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java