第九章 集合

简介: 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 位集
相关文章
|
数据采集 监控 物联网
一些常用的 Salesforce IoT Cloud 中间件工具
以下是一些常用的Salesforce IoT Cloud中间件工具
|
云安全 安全 网络安全
网络安全 | 什么是云安全?
云安全是应对企业外部和内部威胁的关键,它集合了多种程序和技術,确保云服务(如IaaS、PaaS、SaaS)的安全运行。云计算让企业能灵活扩展,但也带来数据安全管理挑战,包括可见性不足、多租户风险、访问控制困难和合规性问题。配置错误也是主要威胁。应对策略包括身份和访问管理(IAM)、数据丢失预防(DLP)、信息安全和事件管理(SIEM)以及业务连续性和灾难恢复计划。企业需构建安全的云计算框架,遵循网络安全框架,并利用云安全态势管理(CSPM)来防止错误配置造成的风险。
428 0
|
消息中间件 存储 负载均衡
kafka核心原理,藏在这 16 张图里
kafka核心原理,藏在这 16 张图里
717 0
|
8月前
|
安全 Java 数据安全/隐私保护
Spring Security: 深入解析 AuthenticationSuccessHandler
本文深入解析了 Spring Security 中的 `AuthenticationSuccessHandler` 接口,它用于处理用户认证成功后的逻辑。通过实现该接口,开发者可自定义页面跳转、日志记录等功能。文章详细讲解了接口方法参数及使用场景,并提供了一个根据用户角色动态跳转页面的示例。结合 Spring Security 配置,展示了如何注册自定义的成功处理器,帮助开发者灵活应对认证后的多样化需求。
264 2
|
缓存 NoSQL PHP
使用PHP-redis实现键空间通知监听key失效事件的技术与代码示例
通过上述方法,你可以有效地在PHP中使用Redis来监听键空间通知,特别是针对键失效事件。这可以帮助你更好地管理缓存策略,及时响应键的变化。
259 3
|
运维 负载均衡 安全
slb传统硬件负载均衡器的性能瓶颈
【11月更文挑战第3天】
368 4
|
JavaScript
vue中使用 HotKeys.js 教程(按键响应、快捷键开发)
vue中使用 HotKeys.js 教程(按键响应、快捷键开发)
473 0
|
12月前
|
安全 算法 网络安全
HTTP和HTTPS的区别
本文介绍HTTP与HTTPS的区别、HTTPS链接建立过程及常见加密算法。HTTP为明文传输,易被窃听;HTTPS通过SSL/TLS协议加密,确保数据安全。HTTPS使用端口443,提供认证机制。文中还详细讲解了对称加密(如AES、DES)和非对称加密(如RSA、ECC)算法的特点及应用场景。
|
12月前
|
SQL DataWorks 搜索推荐
DataWorks 产品评测:数据处理的最佳实践与体验
DataWorks是阿里巴巴云推出的一款综合型大数据开发治理平台,通过此次用户画像分析实践,展现了其在数据整合、分析及可视化方面的强大能力。该平台支持自动化ETL流程,优化了数据资产管理与决策支持,提升了跨部门协作效率,促进了业务创新。相比其他工具,DataWorks具备全面的服务生态、高性能计算能力和高智能化水平,尤其适用于处理大规模数据集。新版Data Studio进一步增强了用户体验,集成了Notebook环境与智能助手Copilot,大幅提高了开发效率。尽管存在一些小问题,但整体上,DataWorks是企业实现数字化转型的理想选择。
254 8