JAVAEE初阶相关内容第十一弹续集--多线程(进阶)之常见面试题汇总1

目录

一、锁策略

1.怎么理解乐观锁和悲观锁,具体怎么实现?

2.介绍一下读写锁?

3.什么是自旋锁,为什么要使用自旋锁策略,缺点是什么?

4.Synchronized是可重入锁么?

二、CAS

1.讲解一下理解的CAS机制

2.ABA问题怎么解决

三、Synchronized原理

1.什么是偏向锁

2.synchronized的实现原理?


一、锁策略

1.怎么理解乐观锁和悲观锁,具体怎么实现?

悲观锁认为多个线程访问一个同一个共享变量的冲突的概率较大,会在每次访问共享变量之前都去真正的加锁。

乐观锁认为多个线程访问同一个变量冲突的概率不大,并不会真正加锁,而是尝试直接访问数据,在访问的同时识别当前的数据是否出现访问冲突。

悲观锁的实现是先加锁,比如借助OS提供的mutex,获取到锁再操作数据,获取不到锁就等待。

乐观锁的实现可以引入一个版本号,借助版本号识别当前的数据访问是否冲突。

2.介绍一下读写锁?

读写锁就是把读操作和写操作分别进行加锁。

读锁和读锁之间不互斥

写锁和写锁之间互斥

写锁和读锁之间互斥

读写锁最主要用在“频繁读,不频繁写”的场景中。

3.什么是自旋锁,为什么要使用自旋锁策略,缺点是什么?

如果获取锁失败,立即再尝试获取,无限循环,直到获取到锁位置。第一次获取锁失败,第二次会在极短的时间内到来,一旦锁被其他线程释放,就能第一时间获取到锁

相比于挂起等待锁来说

优点:没有放弃CPU的资源,一旦锁被释放就能第一时间获取到锁,更高效,在锁持有时间比较短的场景下是非常适用的。

缺点:如果锁的持有时间比较长,就会浪费CPU资源。

4.Synchronized是可重入锁么?

是可重入锁。可重入锁指的就是连续加锁两次不会导致死锁。实现的方式是在锁中记录该锁持有的线程身份,以及一个计数器(记录加锁的次数),如果发现当前的加锁线程就是持有锁的线程,则直接计数自增。

二、CAS

1.讲解一下理解的CAS机制

全称Compare and swap ,即“比较和交换”,相当于通过一个原子操作,同时完成“读取内存,比较是否相等,修改内存”这三个步骤,本质上需要CPU指令支撑。

2.ABA问题怎么解决

给要修改的数据引入版本号,在CAS比较数据当前值和旧值的同时,也要比较版本号是否符合预期。如果发现当前版本号和之前读到的版本号一致,就真正的执行修改操作,并让版本号自增。如果发现当前版本号比之前读到的版本号大,就认为操作失败。

三、Synchronized原理

1.什么是偏向锁

偏向锁不是真正的加锁,而是在锁的对象头中记录一个标记(记录该锁锁属的线程),如果没有其他线程参与竞争锁,那么就不会真正的加锁执行,从而降低程序的开销,一旦真正的涉及到其他的线程竞争,再取消偏向锁状态,进入轻量级锁状态。

2.synchronized的实现原理?

参考下方博客的第三部分全部内容

点击跳转博客

  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

西西¥

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值