StackTc 2018-11-16 01:43 采纳率: 90.9%
浏览 1093
已结题

关于悲观锁跟乐观所性能问题 求解

悲观锁机制存在以下问题:  

      1. 在多线程竞争下,加锁、释放锁会导致比较多的上下文切换和调度延时,引起性能问题。

      2. 一个线程持有锁会导致其它所有需要此锁的线程挂起。

      3. 如果一个优先级高的线程等待一个优先级低的线程释放锁会导致优先级倒置,引起性能风险。

    对比于悲观锁的这些问题,另一个更加有效的锁就是乐观锁。其实乐观锁就是:每次不加锁而是假设没有并发冲突而去完成某项操作,如果因为并发冲突失败就重试,直到成功为止。

上面是我百度到的 ,现在有一下场景,如果用悲观锁跟乐观锁去处理 自增加一,分别有10个线程,不管是悲观锁还是乐观锁,都只有一个能成功,虽然悲观锁的其中9个线程被挂起,但是乐观锁的其中9个线程是无效执行,为什么说悲观所 由于线程被阻塞消耗比较大呢。

  • 写回答

2条回答 默认 最新

  • oyljerry 2018-11-16 02:52
    关注

    乐观锁就是觉得冲突的概率很小,我们先自己做事情,然后最后提交的时候,看有没有冲突,如果没有就成功,否则就回滚。它应对的情况就是大部分时候,没有那么多冲突
    而悲观锁就是觉得一开始冲突很多,所以先进行抢锁,抢到了,再开始干活。
    所以比较两者,其实更应该看当前任务的处理场景。

    评论

报告相同问题?

悬赏问题

  • ¥15 用verilog实现tanh函数和softplus函数
  • ¥15 求京东批量付款能替代天诚
  • ¥15 slaris 系统断电后,重新开机后一直自动重启
  • ¥15 51寻迹小车定点寻迹
  • ¥15 谁能帮我看看这拒稿理由啥意思啊阿啊
  • ¥15 关于vue2中methods使用call修改this指向的问题
  • ¥15 idea自动补全键位冲突
  • ¥15 请教一下写代码,代码好难
  • ¥15 iis10中如何阻止别人网站重定向到我的网站
  • ¥15 滑块验证码移动速度不一致问题