【Java】fail-fast 机制故障简述
fail-fast 机制是集合世界中比较常见的错误检测机制,通常出现在遍历集合元素的过程中。
但是 fail-fast 机制有时也会导致程序出现深层次的故障。
public class Test01 { public static void main(String[] args) { ArrayList<String> list = new ArrayList<>(); list.add("a"); list.add("b"); list.add("c"); // forEach 循环存在此问题,但是 for 循环无此问题 for (String s : list) { if ("b".equals(s)) { list.remove(s); } System.out.print(s); } } } /* * 预想输出:abc * 实际输出:ab * * c 被跳过,为什么? * */
原因剖析
- 初始时,list 集合的大小
size
等于 3 。 - 然后在集合遍历时,JVM会维护一个初始值为 0 的游标 cursor ,每次遍历之前,都会检查
cursor == size
是否成立,如果成立则认为遍历结束,程序终止;如果不成立,则 cursor 自增 1 ,继续下一次循环。 - 本次代码中,当执行
remove()
方法之后 ,size = size - 1 =2
,这时 cursor 的值恰好也等于 2,符合条件cursor == size
,所以 JVM 便终止程序,导致并没有读取到最后一个值c
。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具