java集合笔记
java集合框架简图(API关系图):
特点和使用总结:
Collection:
-
单列单值.
List:
-
有序(查询顺序和插入顺序一致),有下标(索引),元素允许重复.
ArrayList:
-
地测是动态数组数据结构,在内存中挨着连续开辟空间,查询快,增删慢.
LinkedList:
-
底层是数据链表结构,在内存中不挨着,不连续开辟空间,查询慢,增删快.
Set/HashSet:
-
无序(查询顺序和插入顺序不一致),无下标(索引),元素不允许重复,底层是Hash表
TreeSet:
-
无序,没有索引,不允许重复,可以对元素进行排序,底层是红黑树
Map/HashMap:
-
双列双值,无序(查询顺序和插入顺序不一致),误下标(索引),键不允许重复,值允许重复,键值是一一对应的,叫键值对,java中叫做Entry对象,底层是Hash表数据结构
TreeMap:
-
可以对键进行排序,底层是红黑树
实际开发中如何选择用哪一种集合?
-
根据集合特点来选择,实际开发中多用ArrayList,HashSet,HashMap
使用总结:
-
HashSet,HashMap如果要求属性相同才认为是同一个对象,那么要重写HashCode和equals方法
-
TreeSet,TreeMap如果存储自定义类型,要指定排序规则.要么使用自然排序,要么使用比较器排序
Collection API总结:
Map API总结:
集合遍历总结:
-
List集合:
-
通过toArray方法把集合转换为数组
-
普通for循环结婚get(索引)方法
-
forEach/迭代器
-
-
Set集合:
-
通过toArray将集合转换为数组
-
forEach/迭代器
-
-
Map集合:
-
拿到每一个键,KeySet,对每一个键进行遍历,通过键调用get(键)找到值
-
拿到每一个Entry对象,EntrySet,通过遍历Entry对象获取每一个键和值
-
实际中该用哪种遍历集合呢?
拿到每一个Entry对象
Set<Map.Entry<String, Integer>> entrySet = map.entrySet();
-
for(Map.Entry<String, Integer> en : entrySet) {
System.out.println(en.getKey() + "=" + en.getValue());
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构