ConcurrentHashMap面试

CAS 自旋操作

CAS是compare and swap的缩写,即我们所说的比较交换。cas是一种基于锁的操作,而且是乐观锁。在java中锁分为乐观锁和悲观锁。悲观锁是将资源锁住,等一个之前获得锁的线程释放锁之后,下一个线程才可以访问。而乐观锁采取了一种宽泛的态度,通过某种方式不加锁来处理资源,比如通过给记录加version来获取数据,性能较悲观锁有很大的提高。乐观锁适用于读多写少的情况下面。

CAS 操作包含三个操作数 —— 内存位置(V)、预期原值(A)和新值(B)。如果内存地址里面的值和A的值是一样的,那么就将内存里面的值更新成B。CAS是通过无限循环来获取数据的,若果在第一轮循环中,a线程获取地址里面的值被b线程修改了,那么a线程需要自旋,到下次循环才有可能机会执行。

CAS 存在的问题:

存在的问题: ABA 问题,一个线程将数值 a 改成 b,然后又改成了 a,CAS 是认为没有变化的,其实已经变化了,解决方案加一个版本号。每次操作的时候 version+1.

CPU 利用率增加,CAS 的无限循环判断过程中,如果线程一直没有获取到状态,CPU 资源一直被占用。

alt

alt

alt

ConcurrentHashMap

这个需要和 HashMap 进行比较。

对于 Node 数组,使用 volatile 关键字修饰,防止指令重排序发生。

alt

put 方法进入一个死循环,进行 CAS 操作

alt

alt

ConcurrentHashMap 的 get 方法是不加锁的,table 使用了 volatile 关键字修饰,保证了每次获取的值都是最新的。

alt

concurrenthashmap 是线程安全的容器,在并发情况下面是线程安全的。而 HashMap 是不安全的

允许null 值吗?

HashMap 是允许 null 值的。hashMap 允许一个 key 是 null 值,value 可以允许多个 null 值。

而 currentHashMap 是不允许 null 值的,因为 null 值有两种情况,一个是不存在,还有一个 value 就是 null,有些场景下面 value 就是 null,存在 key 的。那这样就会出现了歧义。

面试题

cuncurrentHashMap 的 get 方法是否需要加锁,为什么?

cuncurrentHashMap 和 HashMap 的区别是什么?

cuncurrentHashMap 在 jdk1.7 和 1.8 的结构分别是什么?做了什么修改

参考:https://blog.csdn.net/u011381576/article/details/79922538

#HashMap##ConcurrentHashMap面试#
牛牛的面试专栏 文章被收录于专栏

牛牛的面试专栏,希望自己在25年可以拿到一份大厂的SP Offer 你的点赞和收藏都是我持续更新的动力

全部评论

相关推荐

鸿雁于飞:1. 求职定位乱成一锅粥,直接劝退HR 你期望职位同时写了「项目经理/技术经理/交付经理」,这仨岗根本不是一个赛道!项目经理玩流程和干系人,技术经理玩架构和带技术团队,交付经理玩客户和回款,你仨全堆上,HR直接判定「这人自己都不知道自己要干啥,没核心竞争力」,直接扔简历。 ​ 2. 2年多的职业空窗期,一个字不提,纯纯自杀行为 金融行业最看重职业连贯性和背景干净,你2018年5月到2020年8月,整整2年3个月没上班,啥说明都没有!HR直接脑补你是不是有竞业限制、是不是创业失败、是不是有啥背调过不了的问题,直接不敢往下看,首轮就给你筛了,这是最致命的坑! ​ 3. 工作经历纯纯摆烂,干货全藏起来了 你每段工作就写个公司、职位、时间,干了啥、带了多大团队、出了啥核心成果、给公司赚了/省了多少钱,一个字没有,全堆到后面的项目里了。HR看简历就3秒,第一眼看不到你每段工作的价值,直接就划走了,根本不会翻你后面的项目。 ​ 4. 项目经验像个大杂烩,还全是bug 你堆了快10个项目,银行、证券、公安、政务、日本项目啥都有,跟个杂货铺一样,HR根本看不到你的核心优势在哪。而且项目连个起止时间都不写,谁知道你这是最近的标杆项目,还是10年前刚入行干的活?还有数据前后矛盾,一会说「零事故交付」,一会说「生产事故率降低50%」,HR一看就觉得你瞎包装,根本不信。 ​ 5. 15年经验的经理岗,还在写一线拧螺丝的活,层级完全错配 你都应聘经理级岗位了,简历里还在写自己写接口、写测试脚本、做前端开发这些一线执行的活,完全没写你怎么搭建管理体系、怎么带团队、怎么搞定甲方、怎么控项目风险、怎么拿经营结果,MBA的价值一点没体现出来。HR看完直接觉得:合着你干了15年,还是个高级开发,根本达不到经理岗的要求,直接pass。 ​ 6. AI风口完全没抓住,写了句空话等于没写 现在全行业都在卷AI+金融,人家招管理岗,都要能落地AI场景的人。你就写了句「深化Transformer与大模型底层技术研习」,纯纯空话,一点实际落地成果都没有,跟其他候选人比,完全没差异化优势,人家凭啥放着年轻能落地的不要,要你这个只学了理论的? 姐好好看看,然后改改简历吧,要专,要精,然后降低求职目标。希望你能早日拿到offer
点赞 评论 收藏
分享
评论
5
14
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务