前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >面试题:fail-safe 机制与 fail-fast 机制分别有什 么作用

面试题:fail-safe 机制与 fail-fast 机制分别有什 么作用

作者头像
向着百万年薪努力的小赵
发布2022-12-02 10:44:25
4050
发布2022-12-02 10:44:25
举报
文章被收录于专栏:小赵的Java学习小赵的Java学习

大家好我是庆威,一个妄想30岁前年薪百万的北漂程序员。 本专栏是我整理的大厂常见面试题,我会给出回答和解析,希望能帮助到大家 如果觉得有帮助,欢迎来访我的其他专栏: 链接: 从源码探究原理 链接: Java并发编程 链接: SQL–知识及原理

在这里插入图片描述
在这里插入图片描述

前段时间一个同学去面试,遇到这样一个问题。

fail-safe 机制与 fail-fast 机制分别有什么作用?

他说他听到这个问题的时候,脑子里满脸问号。

额….嗯…(持续几秒后,贴一个搞笑的图,比如 two years latter 之类,然后再配 个一脸蒙蔽。。)

fail-safe 机制与 fail-fast 机制分别有什 么作用

fail-safe 和 fail-fast,是多线程并发操作集合时的一种失败处理机制。

代码语言:javascript
复制
	Fail-fast:表示快速失败,在集合遍历过程中,一旦发现容器中的数据被修改了, 会立刻抛出 ConcurrentModificationException 异常,从而导致遍历失败,像这种情况。

一般会配合迭代器中使用,比如定义一个 Map 集合,使用 Iterator 迭代器进行数据遍历,在遍历过程中,对集合数据做变更时,就会发生 fail-fast。

java.util 包下的集合类都是快速失败机制的。

常见的的使用 fail-fast 方式遍历的容 器有 HashMap 和 ArrayList 等。

代码语言:javascript
复制
	Fail-safe,表示失败安全,也就是在这种机制下,出现集合元素的修改,不会抛 出 ConcurrentModificationException。

原因是采用安全失败机制的集合容器,在遍历时不是直接在集合内容上访问的, 而是先复制原有集合内容, 在拷贝的集合上进行遍历。

由于迭代时是对原集合的拷贝进行遍历,所以在遍历过程中对原集合所作的修改并不能被迭代器检测到,比如,定义了一个 CopyOnWriteArrayList,在对这个集合遍历过程中,对集合元素做修改后,不会抛出异常,但同时也不会打印出增加的元素。

java.util.concurrent 包下的容器都是安全失败的,可以在多线程下并发使用,并发修改。

常 见 的 的 使 用 fail-safe 方 式 遍 历 的 容 器 有 ConcerrentHashMap 和 CopyOnWriteArrayList 等。

本文参与?腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-07-12,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客?前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • fail-safe 机制与 fail-fast 机制分别有什 么作用
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
http://www.vxiaotou.com