在阅读《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 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