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 做个有关计算的小程序
  • ¥15 MPI读取tif文件无法正常给各进程分配路径
  • ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
  • ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
  • ¥15 setInterval 页面闪烁,怎么解决
  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化