Java 教程
- Java - 首页
- Java - 概述
- Java - 历史
- Java - 特性
- Java 与 C++
- JVM - Java 虚拟机
- Java - JDK 与 JRE 与 JVM
- Java - Hello World 程序
- Java - 环境搭建
- Java - 基本语法
- Java - 变量类型
- Java - 数据类型
- Java - 类型转换
- Java - Unicode 系统
- Java - 基本运算符
- Java - 注释
- Java - 用户输入
- Java - 日期和时间
Java 控制语句
- Java - 循环控制
- Java - 决策制定
- Java - If-else
- Java - Switch
- Java - For 循环
- Java - For-Each 循环
- Java - While 循环
- Java - do-while 循环
- Java - Break
- Java - Continue
面向对象编程
- Java - OOPs 概念
- Java - 对象和类
- Java - 类属性
- Java - 类方法
- Java - 方法
- Java - 变量作用域
- Java - 构造函数
- Java - 访问修饰符
- Java - 继承
- Java - 聚合
- Java - 多态
- Java - 重写
- Java - 方法重载
- Java - 动态绑定
- Java - 静态绑定
- Java - 实例初始化块
- Java - 抽象
- Java - 封装
- Java - 接口
- Java - 包
- Java - 内部类
- Java - 静态类
- Java - 匿名类
- Java - 单例类
- Java - 包装类
- Java - 枚举
- Java - 枚举构造函数
- Java - 枚举字符串
Java 内置类
Java 文件处理
Java 错误和异常
- Java - 异常
- Java - try-catch 块
- Java - try-with-resources
- Java - 多重 catch 块
- Java - 嵌套 try 块
- Java - Finally 块
- Java - throw 异常
- Java - 异常传播
- Java - 内置异常
- Java - 自定义异常
Java 多线程
- Java - 多线程
- Java - 线程生命周期
- Java - 创建线程
- Java - 启动线程
- Java - 线程连接
- Java - 线程命名
- Java - 线程调度器
- Java - 线程池
- Java - 主线程
- Java - 线程优先级
- Java - 守护线程
- Java - 线程组
- Java - 关闭钩子
Java 同步
Java 网络
- Java - 网络
- Java - 套接字编程
- Java - URL 处理
- Java - URL 类
- Java - URLConnection 类
- Java - HttpURLConnection 类
- Java - Socket 类
- Java - 泛型
Java 集合
Java 接口
Java 数据结构
Java 集合算法
高级 Java
- Java - 命令行参数
- Java - Lambda 表达式
- Java - 发送邮件
- Java - Applet 基础
- Java - Javadoc 注释
- Java - 自动装箱和拆箱
- Java - 文件不匹配方法
- Java - REPL (JShell)
- Java - 多版本 Jar 文件
- Java - 私有接口方法
- Java - 内部类菱形运算符
- Java - 多分辨率图像 API
- Java - 集合工厂方法
- Java - 模块系统
- Java - Nashorn JavaScript
- Java - Optional 类
- Java - 方法引用
- Java - 函数式接口
- Java - 默认方法
- Java - Base64 编码解码
- Java - Switch 表达式
- Java - Teeing 收集器
- Java - 微基准测试
- Java - 文本块
- Java - 动态 CDS 归档
- Java - Z 垃圾收集器 (ZGC)
- Java - 空指针异常
- Java - 打包工具
- Java - 密封类
- Java - 记录类
- Java - 隐藏类
- Java - 模式匹配
- Java - 紧凑数字格式化
- Java - 垃圾回收
- Java - JIT 编译器
Java 杂项
- Java - 递归
- Java - 正则表达式
- Java - 序列化
- Java - 字符串
- Java - Process API 改进
- Java - Stream API 改进
- Java - 增强的 @Deprecated 注解
- Java - CompletableFuture API 改进
- Java - 流
- Java - Datetime Api
- Java 8 - 新特性
- Java 9 - 新特性
- Java 10 - 新特性
- Java 11 - 新特性
- Java 12 - 新特性
- Java 13 - 新特性
- Java 14 - 新特性
- Java 15 - 新特性
- Java 16 - 新特性
Java API 和框架
Java 类参考
- Java - Scanner
- Java - 数组
- Java - 字符串
- Java - Date
- Java - ArrayList
- Java - Vector
- Java - Stack
- Java - PriorityQueue
- Java - LinkedList
- Java - ArrayDeque
- Java - HashMap
- Java - LinkedHashMap
- Java - WeakHashMap
- Java - EnumMap
- Java - TreeMap
- Java - IdentityHashMap
- Java - HashSet
- Java - EnumSet
- Java - LinkedHashSet
- Java - TreeSet
- Java - BitSet
- Java - Dictionary
- Java - Hashtable
- Java - Properties
- Java - Collection
- Java - Array
Java 有用资源
Java - LinkedList 类
LinkedList 类扩展了 AbstractSequentialList 并实现了 List 接口。它提供了一个链接列表数据结构。
以下是 LinkedList 类支持的构造函数。
序号 | 构造函数和描述 |
---|---|
1 | LinkedList( ) 此构造函数构建一个空的链接列表。 |
2 | LinkedList(Collection c) 此构造函数构建一个链接列表,该列表使用集合 c 的元素进行初始化。 |
除了从其父类继承的方法外,LinkedList 还定义了以下方法:
序号 | 方法和描述 |
---|---|
1 | void add(int index, Object element) 在此列表的指定位置 index 插入指定的元素。如果指定的索引超出范围 (index < 0 || index > size()),则抛出 IndexOutOfBoundsException。 |
2 | boolean add(Object o) 将指定的元素追加到此列表的末尾。 |
3 | boolean addAll(Collection c) 将指定集合中的所有元素追加到此列表的末尾,顺序与指定集合的迭代器返回的顺序相同。如果指定的集合为空,则抛出 NullPointerException。 |
4 | boolean addAll(int index, Collection c) 将指定集合中的所有元素插入到此列表中,从指定位置开始。如果指定的集合为空,则抛出 NullPointerException。 |
5 | void addFirst(Object o) 在此列表的开头插入给定的元素。 |
6 | void addLast(Object o) 将给定的元素追加到此列表的末尾。 |
7 | void clear() 从此列表中删除所有元素。 |
8 | Object clone() 返回此 LinkedList 的浅拷贝。 |
9 | boolean contains(Object o) 如果此列表包含指定的元素,则返回 true。更正式地说,当且仅当此列表至少包含一个元素 e 使得 (o==null ? e==null : o.equals(e)) 时,返回 true。 |
10 | Object get(int index) 返回此列表中指定位置的元素。如果指定的索引超出范围 (index < 0 || index >= size()),则抛出 IndexOutOfBoundsException。 |
11 | Object getFirst() 返回此列表中的第一个元素。如果此列表为空,则抛出 NoSuchElementException。 |
12 | Object getLast() 返回此列表中的最后一个元素。如果此列表为空,则抛出 NoSuchElementException。 |
13 | int indexOf(Object o) 返回此列表中指定元素第一次出现的索引,如果列表不包含此元素,则返回 -1。 |
14 | int lastIndexOf(Object o) 返回此列表中指定元素最后一次出现的索引,如果列表不包含此元素,则返回 -1。 |
15 | ListIterator listIterator(int index) 返回此列表中元素的列表迭代器(按正确顺序),从列表中的指定位置开始。如果指定的索引超出范围 (index < 0 || index >= size()),则抛出 IndexOutOfBoundsException。 |
16 | Object remove(int index) 从此列表中删除指定位置的元素。如果此列表为空,则抛出 NoSuchElementException。 |
17 | boolean remove(Object o) 从此列表中删除指定元素的第一次出现。如果此列表为空,则抛出 NoSuchElementException。如果指定的索引超出范围 (index < 0 || index >= size()),则抛出 IndexOutOfBoundsException。 |
18 | Object removeFirst() 从此列表中删除并返回第一个元素。如果此列表为空,则抛出 NoSuchElementException。 |
19 | Object removeLast() 从此列表中删除并返回最后一个元素。如果此列表为空,则抛出 NoSuchElementException。 |
20 | Object set(int index, Object element) 将此列表中指定位置的元素替换为指定的元素。如果指定的索引超出范围 (index < 0 || index >= size()),则抛出 IndexOutOfBoundsException。 |
21 | int size() 返回此列表中的元素数。 |
22 | Object[] toArray() 返回一个包含此列表中所有元素的数组,顺序正确。如果指定的数组为空,则抛出 NullPointerException。 |
23 | Object[] toArray(Object[] a) 返回一个包含此列表中所有元素的数组,顺序正确;返回数组的运行时类型与指定数组的类型相同。 |
示例
以下程序说明了 LinkedList 支持的几种方法:
import java.util.*; public class LinkedListDemo { public static void main(String args[]) { // create a linked list LinkedList ll = new LinkedList(); // add elements to the linked list ll.add("F"); ll.add("B"); ll.add("D"); ll.add("E"); ll.add("C"); ll.addLast("Z"); ll.addFirst("A"); ll.add(1, "A2"); System.out.println("Original contents of ll: " + ll); // remove elements from the linked list ll.remove("F"); ll.remove(2); System.out.println("Contents of ll after deletion: " + ll); // remove first and last elements ll.removeFirst(); ll.removeLast(); System.out.println("ll after deleting first and last: " + ll); // get and set a value Object val = ll.get(2); ll.set(2, (String) val + " Changed"); System.out.println("ll after change: " + ll); } }
这将产生以下结果:
输出
Original contents of ll: [A, A2, F, B, D, E, C, Z] Contents of ll after deletion: [A, A2, D, E, C, Z] ll after deleting first and last: [A2, D, E, C] ll after change: [A2, D, E Changed, C]