在阅读《java并发编程之美》中 看到关于aqs的实现 发现当一个线程调用release()方法时 会调用unpark方法来唤醒线程 在前面的描述中 unpark方法调用后再次调用park方法不会阻塞线程而是直接返回 那怎么挂起线程呢 而且使用阻塞队列存放线程 fifo先进先出 那不就是相当于公平锁了么那非公平锁怎么实现呢
关于AQS底层实现方法调用
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
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)会使用许可继续执行而不是阻塞,就避免了并发问题。
其次是公平锁和非公平锁的问题,公平锁和非公平锁的区别在于是否允许闯入线程获取锁,非公平锁允许闯入线程获取锁,也就是锁释放后,闯入线程可以立刻获得锁充分利用线程切换的时间,而不是必须唤醒队列首部的线程再去获取锁。并不是说非公平锁就是所有线程都参与竞争,谁获得就是谁的。如果没有闯入线程,那么其实公平锁和非公平锁其实是一样的,都是按照顺序从阻塞队列一个个解锁。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥15 做个有关计算的小程序
- ¥15 MPI读取tif文件无法正常给各进程分配路径
- ¥15 如何用MATLAB实现以下三个公式(有相互嵌套)
- ¥30 关于#算法#的问题:运用EViews第九版本进行一系列计量经济学的时间数列数据回归分析预测问题 求各位帮我解答一下
- ¥15 setInterval 页面闪烁,怎么解决
- ¥15 如何让企业微信机器人实现消息汇总整合
- ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
- ¥15 如何用Python爬取各高校教师公开的教育和工作经历
- ¥15 TLE9879QXA40 电机驱动
- ¥20 对于工程问题的非线性数学模型进行线性化