阿里JAVA面试题剖析:复述的并发竞争问题是什么?如何解决这个问题吗?

  

面试原题

  

复述的并发竞争问题是什么?如何解决这个问题?了解复述,事务的CAS方案吗?

  

面试官心理分析

  

这个也是线上非常常见的一个问题,就是多客户端同时并发写一个<强>键强,可能本来应该先到的数据后到了,导致数据版本错了,或者是多客户端同时获取一个键,修改值之后再写回去,只要<强>顺序错了,数据就错了

  

而且复述,自己就有天然解决这个问题的CAS类的乐观锁方案。

  

面试题剖析

  

某个时刻,多个系统实例都去更新某个<强> 强的关键。可以基于管理员实现分布式锁。每个系统通过饲养员获取分布式锁,确保同一时间,只能有一个系统实例在操作某个钥匙,别人都不允许读和写。

  

阿里JAVA面试题剖析:复述的并发竞争问题是什么?如何解决这个问题?

  

你要写入缓存的数据,都是从mysql里查出来的,都得写入mysql中,写入mysql中的时候必须保存一个时间戳,从mysql查出来的时候,时间戳也查出来。

  

每次要写之前,先判断一下当前这个值的时间戳是否比缓存里的值的时间戳要新。如果是的话,那么可以写,否则,就不能用旧的数据覆盖新的数据。

  

文末彩蛋:

  

<强>针对于上面面试有提到的知识点我总结出了有1到5年开发经验的程序员在面试中涉及到的绝大部分架构面试题及答案做成了文档和架构视频资料免费分享给大家(包括达博,复述,网状的,动物园管理员,春天的云,分布式,高并发等架构技术资料),希望能帮助到您面试前的复习且找到一个好的工作,也节省大家在网上搜索资料的时间来学习,也可以关注我一下以后会有更多干货分享。

  

资料获取方式QQ群搜索“708-701-457”备注“51 cto”即可免费领取

  

阿里JAVA面试题剖析:复述的并发竞争问题是什么?如何解决这个问题?”> <br/> <img src=

阿里JAVA面试题剖析:复述的并发竞争问题是什么?如何解决这个问题吗?