第九章 集合

简介: Java 集合框架集合API中以Abstract开头的类是为类库实现者设计的,扩展这些类比直接实现接口要简单得多集合类的基本接口是Collection,它继承了Iterable接口, 方法iterator()返回Iterator接口, 它是一个迭代器.

Java 集合框架

  • 集合API中以Abstract开头的类是为类库实现者设计的,扩展这些类比直接实现接口要简单得多
  • 集合类的基本接口是Collection,它继承了Iterable接口, 方法iterator()返回Iterator接口, 它是一个迭代器. 注意, 当要删除元素时, 必须先调用next()然后调用remove(), 也就是说remove方法必须与next组合使用.
  • Iterator接口提供了一个函数式方法forEachRemaining(Consumer<? super E> action) 可以做迭代
  • 集合框架中的接口

img_c1b8f826fa2d348009c6851a484ce90e.png

  • RandomAccess是一个标记接口, 可以用它判断集合是否支持高效随机访问
  • Set接口不允许有元素重复. java6新增了NavigableSet,NavigableMap接口, 包含用于遍历和查找的方法

具体的集合

ArrayList: 一种可以动态增长和缩减的索引序列
LinkedList: 一种可以在任何位置进行高效地插人和删除操作的有序序列
ArrayDeque: 一种用循环数组实现的双端队列
HashSet: 一种没有重复元素的无序集合
TreeSet: — 种有序集
EnumSet: 一种包含枚举类型值的集
LinkedHashSet: 一种可以记住元素插人次序的集
PriorityQueue: 一种允许高效删除最小元素的集合
HashMap: 一种存储键/值关联的数据结构
TreeMap: — 种键值有序排列的映射表
EnumMap: 一种键值属于枚举类型的映射表
LinkedHashMap: 一种可以记住键/值项添加次序的映射表
WeakHashMap: 一种其值无用武之地后可以被垃圾回收器回收的映射表
IdentityHashMap: 一种用 == 而不是用 equals 比较键值的映射表

img_df8dcafa8df4b348132aead48548d2e7.png

散列表: 通过计算元素的hash值, 将他们放置在桶中, 每个桶的数据结构是一个链表, 如果查找对象就可以根据hash值与桶数量取余, 然后根据余数获取桶的索引, 再从对应的桶中读取所需元素.

  • 双端队列, Deque接口,有ArrayDeque和LinkedList实现.
  • 优先级队列PriorityQueue, 永远删除的是最小的元素

映射

  • merge, comouter 方法可以使用计算结果更新节点值
  • *ifAbsent() 方法在有元素的时候才执行方法的动作
  • 映射视图,entrySet(),keySet(),values() 等方法返回的是映射视图, 只能删除元素, 不能新增元素.
  • WeakHashMap弱引用映射, 以弱引用方式保存键, GC有一种特有的方式回收不使用的元素
  • EnumSet 使用静态工厂方法生成实例
  • IdentityHashMap 使用==比较, 其hash值是System.identityHashCode()计算得到, 计算的是对象的内存地址.

视图与包装器

  • Array.asList(..) 返回一个视图, 它最终调用Collections.nCopies(n,anObject)
  • sub* 方法返回一个子范围
  • Collections.unmodifiable* 方法返回不可修改的视图
  • 同步视图, Collections.synchronized*()返回的视图可以多线程访问

算法

  • java中的排序是将元素转移到一个数组, 排序完成后copy回去
  • Collections.shuffle()混排元素
  • 二分法查找的前提是数组应该是可以随机访问的, 另外数组是排序的Collections.binarySearch()

遗留的集合

  • Properties 键值对
  • BitSet 位集
相关文章
|
5天前
|
弹性计算 运维 自动驾驶
首个云超算国标正式发布!
近日,我国首个云超算国家标准GB/T 45400-2025正式发布,将于今年10月实施。该标准由阿里云联合多家机构起草,为云超算在高性能计算领域的应用提供规范。云超算结合传统HPC与云计算优势,解决传统HPC复杂、昂贵等问题。阿里云E-HPC V2.0是国内首批通过该标准认证的产品,支持大规模弹性计算,显著降低成本。新标准将推动算力基础设施迈向标准化、智能化新时代。
|
6天前
|
传感器 自然语言处理 监控
快速部署实现Bolt.diy
Bolt.diy 是 Bolt.new 的开源版本,提供灵活的自然语言交互与全栈开发支持。基于阿里云函数计算 FC 和百炼模型服务,最快5分钟完成部署。新手注册阿里云账号后可领取免费额度,按指引开通相关服务并授权。通过项目模板一键部署,配置 API-KEY 后即可使用。Bolt.diy 支持多种场景,如物联网原型开发、久坐提醒、语音控制灯光等,助力快速实现创意应用。
2241 17
|
7天前
|
云安全 人工智能 安全
|
7天前
|
Serverless API
【MCP教程系列】在阿里云百炼,实现超级简单的MCP服务部署
阿里云百炼推出业界首个全生命周期MCP服务,支持一键在线注册托管。企业可将自研或外部MCP服务部署于阿里云百炼平台,借助FC函数计算能力,免去资源购买与服务部署的复杂流程,快速实现开发。创建MCP服务仅需四步,平台提供预置服务与自定义部署选项,如通过npx安装代码配置Flomo等服务。还可直接在控制台开通预置服务,体验高效便捷的企业级解决方案。
【MCP教程系列】在阿里云百炼,实现超级简单的MCP服务部署
|
1月前
|
人工智能 自然语言处理 Java
快速带你上手通义灵码 2.0,体验飞一般的感觉
通义灵码个人版为开发者免费提供智能编码能力,专业版限免期内开放更多功能。使用需先注册阿里云账号,支持JetBrains IDEs、Visual Studio Code等开发工具。以Visual Studio Code为例,安装插件并登录后即可体验其强大功能。通义灵码2.0在代码生成、需求理解及单元测试自动化等方面有显著提升,支持多语言和复杂场景,大幅提高开发效率。
234891 36
快速带你上手通义灵码 2.0,体验飞一般的感觉
|
13天前
|
存储 人工智能 监控
一键部署 Dify + MCP Server,高效开发 AI 智能体应用
本文将着重介绍如何通过 SAE 快速搭建 Dify AI 研发平台,依托 Serverless 架构提供全托管、免运维的解决方案,高效开发 AI 智能体应用。
1880 6
|
5天前
|
人工智能 运维 数据可视化
阿里云百炼 MCP服务使用教程合集
阿里云百炼推出首个全生命周期MCP服务,支持一键部署、无需运维,具备高可用与低成本特点。该服务提供多类型供给、低成本托管及全链路工具兼容,帮助企业快速构建专属智能体。MCP(模型上下文协议)作为标准化开源协议,助力大模型与外部工具高效交互。教程涵盖简单部署、GitHub运营、数据分析可视化及文档自动化等场景,助您快速上手。欢迎加入阿里云百炼生态,共同推动AI技术发展!
|
1月前
|
人工智能 开发工具 C++
利用通义灵码AI在VS Code中快速开发扫雷游戏:Qwen2.5-Max模型的应用实例
本文介绍了如何利用阿里云通义灵码AI程序员的Qwen2.5-Max模型,在VS Code中一键生成扫雷小游戏。通过安装通义灵码插件并配置模型,输入指令即可自动生成包含游戏逻辑与UI设计的Python代码。生成的游戏支持难度选择,运行稳定无Bug。实践表明,AI工具显著提升开发效率,但人机协作仍是未来趋势。建议开发者积极拥抱新技术,同时不断提升自身技能以适应行业发展需求。
22202 17
|
7天前
|
人工智能 API 数据库
MCP Server 开发实战 | 大模型无缝对接 Grafana
以 AI 世界的“USB-C”标准接口——MCP(Model Context Protocol)为例,演示如何通过 MCP Server 实现大模型与阿里云 Grafana 服务的无缝对接,让智能交互更加高效、直观。
472 110
|
7天前
|
人工智能 监控 JavaScript
MCP 正当时:FunctionAI MCP 开发平台来了!
Function AI 是基于函数计算构建的 Serverless AI 应用开发平台,基于函数计算的运行时能力上线了完整的 MCP 开发能力,您可以进入 FunctionAI 控制台,快速体验 MCP 服务的能力。
399 10

热门文章

最新文章