Hazardeden17 2021-09-29 21:05 采纳率: 100%
浏览 24
已结题

关于AQS底层实现方法调用

在阅读《java并发编程之美》中 看到关于aqs的实现 发现当一个线程调用release()方法时 会调用unpark方法来唤醒线程 在前面的描述中 unpark方法调用后再次调用park方法不会阻塞线程而是直接返回 那怎么挂起线程呢 而且使用阻塞队列存放线程 fifo先进先出 那不就是相当于公平锁了么那非公平锁怎么实现呢

img

  • 写回答

1条回答 默认 最新

  • yue_hu 2021-09-30 10:20
    关注

    首先是unpark方法,unpark方法在线程处于阻塞状态时唤醒线程,线程未阻塞状态时会给予一个许可,如果有许可的情况下调用park方法就会直接消耗这个许可不阻塞线程,但是许可消耗后再次调用park就会阻塞了,在前面的描述中 unpark方法调用后再次调用park方法不会阻塞线程而是直接返回就是指的这种情况。设置许可的目的是为了更好的应对并发问题,假设锁释放并执行唤醒操作在当前线程的是否阻塞判断之后执行LockSupport.park(Object)之前,没有许可的话当前线程执行LockSupport.park(Object)就会直接阻塞,导致所有线程都处于阻塞状态,进而形成死锁。而使用许可LockSupport.unpark(Object)会赋予当前线程一个许可,此时执行LockSupport.park(Object)会使用许可继续执行而不是阻塞,就避免了并发问题。
    其次是公平锁和非公平锁的问题,公平锁和非公平锁的区别在于是否允许闯入线程获取锁,非公平锁允许闯入线程获取锁,也就是锁释放后,闯入线程可以立刻获得锁充分利用线程切换的时间,而不是必须唤醒队列首部的线程再去获取锁。并不是说非公平锁就是所有线程都参与竞争,谁获得就是谁的。如果没有闯入线程,那么其实公平锁和非公平锁其实是一样的,都是按照顺序从阻塞队列一个个解锁。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月8日
  • 已采纳回答 9月30日
  • 创建了问题 9月29日

悬赏问题

  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line