主页
  • 主页
  • 分类
  • 热文
  • 教程
  • 面试
  • 标签
Java

Java 基础

Java 主页
Java 概述
Java 历史
Java 功能
Java 与 C++
Java 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 面向对象编程

Java OOP概念
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 数组
Java 数学类

Java 文件处理

Java 文件
Java 创建文件
Java 写入文件
Java 读取文件
Java 删除文件
Java 目录操作
Java I/O流

Java 错误和异常

Java 异常
Java Try Catch
Java try-with-resources
Java 多个 Catch
Java 嵌套 try
Java finally
Java 抛出异常
Java 异常传播
Java 内置异常
Java 自定义异常

Java 多线程

Java 多线程
Java 线程生命周期
Java 创建线程
Java 启动线程
Java 加入线程
Java 命名线程
Java 线程调度
Java 线程池
Java 主线程
Java 线程优先级
Java 守护线程
Java 线程组
Java JVM 关闭

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 映射接口
Java SortedMap 接口
Java 集合(Set)接口
Java SortedSet 接口

Java 数据结构

Java 数据结构
Java 枚举接口

Java 集合算法

Java 迭代器
Java 比较器
Java Comparable 接口

Java 高级

Java 命令行参数
Java Lambda 表达式
Java 发送电子邮件
Java 小应用程序
Java Javadoc
Java 自动装箱和拆箱
Java mismatch() 方法
Java REPL
Java 多版本发布 JAR
Java 私有接口方法
Java 金刚石操作符
Java 多分辨率图像 API
Java 集合的工厂方法
Java 模块系统
Java Nashorn 引擎
Java Optional 类
Java 方法引用
Java 功能接口
Java 默认方法
Java Base64 工具类
Java Switch 表达式
Java Collectors.teeing() 方法
Java 基准测试
Java 文本块
Java 动态CDS
Java ZGC
Java NullPointerException
Java jpackage
Java 密封类
Java 记录
Java 隐藏类
Java instanceof
Java 紧凑数字格式化
Java 垃圾回收
Java JIT 编译器

Java 杂项

Java 递归
Java 正则表达式
Java 序列化
Java 字符串类
Java 进程 API
Java Stream API
Java @Deprecated 注释
Java CompletableFuture API
Java Streams
Java 日期时间 API

基础

Java 主页
Java 概述
Java 历史
Java 功能
Java 与 C++
Java JVM(Java虚拟机)
Java JDK、JRE 和 JVM
Java Hello World 程序
Java 环境设置
Java 基本语法
Java 变量类型
Java 数据类型
Java 类型转换
Java Unicode 系统
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 OOP概念
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 数学类

文件处理

Java 文件
Java 创建文件
Java 写入文件
Java 读取文件
Java 删除文件
Java 目录操作
Java I/O流

错误和异常

Java 异常
Java Try Catch
Java try-with-resources
Java 多个 Catch
Java 嵌套 try
Java finally
Java 抛出异常
Java 异常传播
Java 内置异常
Java 自定义异常

多线程

Java 多线程
Java 线程生命周期
Java 创建线程
Java 启动线程
Java 加入线程
Java 命名线程
Java 线程调度
Java 线程池
Java 主线程
Java 线程优先级
Java 守护线程
Java 线程组
Java JVM 关闭

同步

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 SortedMap 接口
Java 集合(Set)接口
Java SortedSet 接口

数据结构

Java 数据结构
Java 枚举接口

集合算法

Java 迭代器
Java 比较器
Java Comparable 接口

高级

Java 命令行参数
Java Lambda 表达式
Java 发送电子邮件
Java 小应用程序
Java Javadoc
Java 自动装箱和拆箱
Java mismatch() 方法
Java REPL
Java 多版本发布 JAR
Java 私有接口方法
Java 金刚石操作符
Java 多分辨率图像 API
Java 集合的工厂方法
Java 模块系统
Java Nashorn 引擎
Java Optional 类
Java 方法引用
Java 功能接口
Java 默认方法
Java Base64 工具类
Java Switch 表达式
Java Collectors.teeing() 方法
Java 基准测试
Java 文本块
Java 动态CDS
Java ZGC
Java NullPointerException
Java jpackage
Java 密封类
Java 记录
Java 隐藏类
Java instanceof
Java 紧凑数字格式化
Java 垃圾回收
Java JIT 编译器

杂项

Java 递归
Java 正则表达式
Java 序列化
Java 字符串类
Java 进程 API
Java Stream API
Java @Deprecated 注释
Java CompletableFuture API
Java Streams
Java 日期时间 API

Java 集合框架


上一章 下一章

在 Java 2 之前,Java 提供了一些临时性的类如 Dictionary、Vector、Stack 和 Properties 来存储和操作对象组。尽管这些类非常有用,但它们缺乏一个中心统一的主题。因此,使用 Vector 的方式与使用 Properties 的方式不同。

为什么使用集合框架?

集合框架的设计是为了满足几个目标,例如:

  • 框架必须具有高性能。基础集合(动态数组、链表、树和哈希表)的实现应当高效。

  • 框架必须允许不同类型集合以类似的方式工作,并具有高度的互操作性。

  • 框架必须易于扩展和/或适应集合。

为了达到这些目的,整个集合框架都是围绕一系列标准接口设计的。提供了一些标准实现如 LinkedList、HashSet 和 TreeSet,您可以直接使用这些实现,也可以选择自己实现集合。

Java 集合框架

集合框架是一种表示和操作集合的统一架构。所有集合框架都包含以下内容:

  • 接口 — 这些是抽象数据类型,表示集合。接口允许独立于其实现细节来操纵集合。在面向对象语言中,接口通常形成一个层次结构。

  • 实现,即类 — 这些是集合接口的具体实现。本质上,它们是可重用的数据结构。

  • 算法 — 这些是对实现了集合接口的对象执行有用计算(如搜索和排序)的方法。算法被认为是多态的:也就是说,相同的方法可以用于许多不同的适当集合接口实现。

除了集合外,框架还定义了几种映射接口和类。映射存储键/值对。虽然严格意义上来说映射不是集合,但它们与集合完全集成。

集合框架层次结构

所有集合框架的类和接口都存在于 java.utli 包中。下图显示了 Java 中集合框架的层次结构:

收集框架的层次结构

Java 集合接口

集合框架定义了几个接口。本节提供每个接口的概述:

序号 接口 & 描述
1 Collection 接口
使您能够处理对象组;它是集合层次结构的顶部。
2 List 接口
扩展 Collection,实例化 List 存储有序的元素集合。
3 Set
扩展 Collection 以处理集合并必须包含唯一元素。
4 SortedSet
扩展 Set 以处理排序集。
5 Map
将唯一键映射到值。
6 Map.Entry
描述映射中的元素(键/值对)。这是 Map 的内部类。
7 SortedMap
扩展 Map 以便维护键的升序。
8 Enumeration
这是遗留接口定义了枚举(一次获取一个)集合中的元素的方法。此遗留接口已被 Iterator 取代。

Java 集合类

Java 提供了一组标准集合类,实现了集合接口。某些类提供了完整的实现可以直接使用,而另一些则是抽象类,提供了骨架实现,可以用作创建具体集合的起点。

标准集合类在下表中进行了总结:

序号 类 & 描述
1 AbstractCollection
实现了大部分 Collection 接口。
2 AbstractList
扩展 AbstractCollection 并实现了大部分 List 接口。
3 AbstractSequentialList
扩展 AbstractList 用于使用顺序而不是随机访问其元素的集合。
4 LinkedList
通过扩展 AbstractSequentialList 实现链表。
5 ArrayList
通过扩展 AbstractList 实现动态数组。
6 AbstractSet
扩展 AbstractCollection 并实现了大部分 Set 接口。
7 HashSet
扩展 AbstractSet 以使用散列表。
8 LinkedHashSet
扩展 HashSet 允许插入顺序迭代。
9 TreeSet
实现在树中存储的集合。扩展 AbstractSet。
10 AbstractMap
实现了大部分 Map 接口。
11 HashMap
扩展 AbstractMap 使用散列表。
12 TreeMap
扩展 AbstractMap 使用树。
13 WeakHashMap
扩展 AbstractMap 使用弱键的散列表。
14 LinkedHashMap
扩展 HashMap 允许插入顺序迭代。
15 IdentityHashMap
扩展 AbstractMap 在比较文档时使用引用相等性。

AbstractCollection、AbstractSet、AbstractList、AbstractSequentialList 和 AbstractMap 类提供了核心集合接口的骨架实现,以尽量减少实现它们所需的努力。

以下是一些 java.util 包中定义的遗留类:

序号 类 & 描述
1 Vector
实现动态数组。类似于 ArrayList,但有一些差异。
2 Stack
Stack 是 Vector 的子类,实现了标准的后进先出栈。
3 Dictionary
Dictionary 是一个抽象类,表示键/值存储库,其操作类似于 Map。
4 Hashtable
是原始 java.util 包的一部分,是 Dictionary 的具体实现。
5 Properties
是 Hashtable 的子类,用于维护键为字符串且值也为字符串的值列表。
6 PriorityQueue
PriorityQueue 类是一个基于优先级堆的无界优先队列。依赖自然排序的优先队列也不允许插入不可比较的对象。
7 BitSet
BitSet 类创建一种特殊类型的数组,持有位值。此数组可以根据需要增长。
8 ArrayDeque
ArrayDeque 类提供可调整大小的数组并实现了 Deque 接口。数组双端队列没有容量限制,因此可以根据需要增长。
9 EnumMap
EnumMap 类是专门用于使用枚举键的 Map 实现。所有 EnumMap 的键必须来自创建时显式或隐式指定的单个枚举类型。
10 Queue
java.util 包中提供的队列接口实现了 Collection 接口。队列实现了 FIFO 即先进先出。这意味着首先进入的元素也是首先被删除的。
11 Deque
EnumMap 类是专门用于使用枚举键的 Map 实现。所有 EnumMap 的键必须来自创建时显式或隐式指定的单个枚举类型。

集合算法

集合框架定义了几种可以应用于集合和映射的算法。这些算法定义为 Collections 类中的静态方法。

一些方法可能会抛出 ClassCastException,当尝试比较不兼容的类型时发生,或者抛出 UnsupportedOperationException,当尝试修改不可修改的集合时发生。

集合定义了三个静态变量:EMPTY_SET、EMPTY_LIST 和 EMPTY_MAP。所有都是不可变的。

序号 算法 & 描述
1 集合算法
以下是所有算法实现的列表。

如何使用迭代器?

通常情况下,您希望遍历集合中的元素。例如,您可能想要显示每个元素。

最简单的方法是使用迭代器,这是一个实现了 Iterator 或 ListIterator 接口的对象。

迭代器使您能够在集合中循环,获取或移除元素。ListIterator 扩展了 Iterator,以允许双向遍历列表以及修改元素。

序号 迭代器方法 & 描述
1 使用 Java Iterator
以下是 Iterator 和 ListIterator 接口提供的所有方法及其示例的列表。

如何使用 Comparator?

TreeSet 和 TreeMap 将元素存储在排序顺序中。然而,正是比较器定义了确切的排序顺序。

这个接口让我们可以按照任意数量的不同方式对给定集合进行排序。此外,此接口可用于排序任何类的实例(即使是我们无法修改的类)。

序号 迭代器方法 & 描述
1 使用 Java Comparator
以下是 Comparator 接口提供的所有方法及其示例的列表。

如何使用 Comparable?

TreeSet 和 TreeMap 将元素存储在排序顺序中。我们可以使用 Comparable 接口来定义确切的排序顺序。

这个接口让我们可以按照任意数量的不同方式对给定集合进行排序。此外,此接口可用于排序任何类的实例(即使是我们无法修改的类)。

序号 迭代器方法 & 描述
1 使用 Java Comparable
以下是 Comparable 接口提供的所有方法及其示例的列表。

总结

Java 集合框架为程序员提供了预包装的数据结构以及操作这些数据结构的算法。

集合是一个可以保存对其他对象引用的对象。集合接口声明了可以对每种类型的集合执行的操作。

集合框架的类和接口位于 java.util 包中。

上一章 下一章
阅读号二维码

关注阅读号

联系二维码

联系我们

© 2024 Yoagoa. All rights reserved.

粤ICP备18007391号

站点地图