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编辑  收藏  举报

导航