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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值