JAVA中的集合框架

Collection 接口

Collection是所有单值集合的顶级接口,它不直接实现任何具体集合,但它定义了集合的基本操作,如添加、删除、检查成员、遍历等。Collection接口有几个子接口,包括 List,Set 和Queue,它们分别代表不同类型的集合。

set接口

HashSet:基于 HashMap 实现的,不保证集合的迭代顺序;允许使用 null 元素。

HashSet不是同步的,如果多个线程同时访问一个Set,只要有一个线程修改Set中的值,就必须进行同步处理,通常通过同步封装这个Set的对象来完成同步,如果不存在这样的对象,可以使用Collections.synchronizedSet()方法完成。

在创建时使用语句 Set s = Collections.synchronizedSet(new HashSet(...)); 防止意外的对集合的非同步访问

LinkedHashSet:具有 HashSet 的所有特性,同时遍历其内部元素时,可以按照元素被添加到集合中的顺序(插入顺序)进行遍历

TreeSet:基于 TreeMap 的 NavigableSet 实现,可以确保集合元素处于排序状态

Queue接口

LinkedList(也实现了 Queue 接口):作为列表时提供了基于链表的所有操作,作为队列时提供了队列的所有操作。

PriorityQueue:基于优先级堆的一个无界优先级队列。

ArrayDeque:是一个基于数组的双端队列,支持在两端插入和移除元素

List 接口

ArrayList:基于动态数组实现的列表,允许包含重复元素。

LinkedList:基于链表实现的列表,允许包含重复元素,且提供了额外的双端队列操作。

Vector:与 ArrayList 类似,但它是同步的,意味着它在多线程环境下是安全的,但性能相对较差。

Stack:继承自 Vector,实现了一个后进先出(LIFO)的堆栈。

Map 接口

Map 接口用于存储键值对集合,一个键可以映射到最多一个值。

HashMap:基于哈希表的 Map 接口实现,允许使用 null 值和 null 键。

LinkedHashMap:是 HashMap 的一个子类,它维护着一个运行于所有条目的双重链接列表。此链接列表定义了迭代器的遍历顺序,该顺序可以是插入顺序或者是访问顺序。

TreeMap:基于红黑树(Red-Black tree)的 NavigableMap 实现,可以确保映射按照键的自然顺序进行排序,或者根据创建映射时提供的 Comparator 进行排序。

Hashtable:是同步的,类似于 HashMap,但它不允许 null 键和 null 值。

Properties:继承自 Hashtable,表示一个持久的属性集,可以保存在流中或从流中加载。

相关推荐
工程师老罗1 天前
Image(图像)的用法
java·前端·javascript
leo_messi941 天前
2026版商城项目(一)
java·elasticsearch·k8s·springcloud
globaldomain1 天前
什么是用于长距离高速传输的TCP窗口扩展?
开发语言·网络·php
美味蛋炒饭.1 天前
Tomcat 超详细入门教程(安装 + 目录 + 配置 + 部署 + 排错)
java·tomcat
沈阳信息学奥赛培训1 天前
#undef 指令 (C/C++)
c语言·开发语言·c++
2401_873204651 天前
分布式系统安全通信
开发语言·c++·算法
dreamxian1 天前
苍穹外卖day11
java·spring boot·后端·spring·mybatis
Veggie261 天前
【Java深度学习】PyTorch On Java 系列课程 第八章 17 :模型评估【AI Infra 3.0】[PyTorch Java 硕士研一课程]
java·人工智能·深度学习
weisian1511 天前
Java并发编程--19-ThreadPoolExecutor七参数详解:拒绝Executors,手动掌控线程池
java·线程池·threadpool·七大参数
csdn5659738501 天前
Java打包时,本地仓库有jar 包,Maven打包却还去远程拉取
java·maven·jar