当前位置: 首页 > news >正文

java list 与set 集合的迭代器在进行元素操作时出现数据混乱问题及原因

为什么 List 和 Set 迭代器删除结果不同?

1. List 和 Set 的本质差异
  • List(如 ArrayList):
    • 有序集合,元素按插入顺序存储,允许重复元素。
    • 迭代器遍历时,元素按索引顺序返回。
    • 删除操作(通过 Iterator.remove())会移除当前元素,影响后续索引,但不改变其他元素的相对顺序。
  • Set(如 HashSet):
    • 无序集合,元素无固定顺序,不允许重复元素(基于 equals 和 hashCode)。
    • 迭代器遍历顺序不可预测(HashSet 依赖哈希表,顺序可能随实现或 JVM 变化)。
    • 删除操作会移除当前元素,但由于无序性,结果表现可能与预期不同。
2. 迭代器删除行为
  • Iterator.remove()
    • Java 的 Iterator 接口提供 remove() 方法,用于在迭代过程中安全删除元素,避免 ConcurrentModificationException。
    • 删除操作基于当前迭代位置,List 和 Set 的底层数据结构导致不同表现:
      • List:删除元素后,后续元素索引前移,迭代器继续按顺序遍历剩余元素。
      • Set:删除元素不影响其他元素的“位置”(因为无序),但遍历顺序可能因哈希表重排而变化。
3. 差异的原因
  • 顺序性
    • List 的迭代器按索引顺序遍历,删除后结果可预测(剩余元素按原顺序)。
    • Set 的迭代器遍历顺序不可预测(HashSet 依赖哈希桶),删除后剩余元素的顺序可能与初始不同。
  • 重复性
    • List 允许重复元素,删除特定元素只移除当前迭代的实例。
    • Set 不允许重复,删除元素后集合中该元素完全移除。
  • 底层实现
    • ArrayList 使用数组,删除操作会导致数组元素移位。
    • HashSet 使用哈希表,删除操作只移除哈希桶中的元素,不影响其他桶。
http://www.dtcms.com/a/290409.html

相关文章:

  • 7.21 树&递归
  • 计算机发展史:互联网时代的万物互联与全球变革
  • ssms(SQL 查询编辑器) 添加快捷键 Ctrl+D(功能等于Ctrl+C + Ctrl+V),一步到位
  • AC身份认证实验之AAA服务器
  • GStreamer开发笔记(九):gst-rtcp-server安装和部署实现简单的rtsp-server服务器推流Demo
  • 事务并发-封锁协议
  • Linux网络信息(含ssh服务和rsync)
  • 工业上位机开发选型:WinForms稳、WPF炫、Avalonia跨平台
  • 今日Github热门仓库推荐 第七期
  • 一.AD域与DFS集群-AD域安装
  • LP-MSPM0G3507学习--09定时器之四输出PWM
  • 3x3矩阵教程
  • 数据结构堆的实现(C语言)
  • 如果通过源码技术实现矩阵系统分部门管理?
  • cocos中实现3d人物角色头顶信息跟随功能,UI跟随3D/2D对象移动,例如昵称血条跟随人物移动
  • 开启PHP编程之旅:从基础语法到项目实践
  • QT6 源,七章对话框与多窗体(6) 颜色对话框 QColorDialog :本类的属性,信号函数,静态成员函数,以及源代码
  • 什么是GNN?——聚合、更新与循环
  • 时间管理的视觉艺术 《时间格子计算器》H5案例赏析
  • 图立得-html纯前端图片拾色器V202507
  • js迭代器
  • 【前端状态更新与异步协调完全指南:React、Vue架构原理与复杂业务场景实战】
  • React-useEffect的闭包陷阱(stale closure)
  • MySQL的在线模式学习笔记
  • HarmonyOS之UIAbility简介
  • redis 如何优雅地进行键设计?
  • 【Spark征服之路-3.6-Spark-SQL核心编程(五)】
  • Spring @RequestBody注解详解与实践
  • oracle 数据库中,将几张表的数据按指定日期范围实时同步至同一个数据库的备份表中。
  • Oracle 数据库共享池与大池调优指南