AQS 同步组件的使用介绍
AQS 实现原理,源码查看
int state
X锁
S锁
acquire()
release()
常用组件
CountDownLatch
- 线程同步,
- 典型应用场景:
并行调用多个服务(异步、缩短时间),都执行完成后,执行后续主流程,异步转同步的典型用法。 - 基本用法:
countDown()
await() - 带超时限制的
await with timeout - 注意事项
- 确保countDown 无遗漏,如果子任务出现异常导致countDown()没有执行,则主流程await()会一直阻塞,安全起见,await with timeout是有必要的。
Semaphore
- 信号量机制,类似进程通信的信号量机制,受限的资源并发访问,可以通过这个类限制并发数。
- release() 信号量归还,增加信号量
- acquire() 信号量获取,拿到锁定资源,信号量减少,可以一次性获取多个信号量。小于0则阻塞,等待其他线程归还。
- tryAcquire() 尝试获取,获取到则执行,获取不到,不执行、不阻塞。
CyclicBarrier
reset()
await()
- 多个线程相互等待,到达同一个条件后,各自执行后续逻辑。可重用的Barrier.
ReentrantLock
可重入锁
计数器机制
jvm层面实现的
Synchronized
cas
功能性
synchronized
fair /unfair
自旋锁 ,线程切换的方面
Condition
分组唤醒需要唤醒的线程
FutureTask
posted on 2020-04-26 21:36 coding-now 阅读(44) 评论(0) 编辑 收藏 举报