AQS以及并发锁,并发队列

AQS 抽象同步队列
  • 双向队列
  • 维护一个state:
    ReentrantLock —> 可重入次数 可指定公平或非公平 默认非公平
    ReentrantReadWriteLock —> 高16位读状态,低16位写状态 CAS实现读写分离 适合读多写少的场景
    Semaphore —> 信号个数
    CountDownlatch —> 计数器当前值
  • 获取资源:tryAcquare()
  • 释放资源:tryRelease()
  • 内部类 ConditionObject
条件变量Condition的使用

ReentrantLock lock = new ReentrantLock();
Condition condition = lock.newCondition();

lock.lock();
try{
condition.await();
} catch(Exception e){

} finally{
lock.unlock();
}

lock.lock();
try{
condition.signal();
} catch(Exception e){

} finally{
lock.unlock();
}

加锁方式比synchronize更灵活

await和signal能实现 wait notify

并发队列
  • ConcurrentLinkedQueue:无界非阻塞 单向链表实现 CAS保证线程安全
  • LinkedBlockingQueue:有界/无界阻塞 单向链表实现 生产者消费者模型 队列两端各一个ReentrantLock
  • ArrayBlockingQueue:有界阻塞 数组实现 全局锁
  • PriorityBlockingQueue:无界阻塞 平衡二叉树堆实现 具有优先级 无序 CAS扩容
  • DelayQueue:无界阻塞 PriorityQueue实现 ReentrantLock保证线程安全 有过期时间 应用于缓存系统的设计、定时任务调度
  • SynchronousQueue:阻塞 不存储元素 传递性场景
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值