java队列小日记

  1. ArrayBlockingQueue
    1. 内部使用一个数组作为其存储空间,数组的存储空间是预先分配的。
    2. 优点:put和take操作不会增加GC的负担
    3. 缺点:put和take操作使用同一个锁,可能导致锁争用,导致较多的上下文切换
    4. 适合在生产者线程和消费者线程之间的并发程序较低的情况下使用
  2. LinkedBlockingQueue
    1. 内部存储空间是一个链表,而链表节点所需的存储空间是动态分配的
    2. 优点:put和take操作使用两个显示锁(putLock和takeLock)
    3. 缺点:增加了GC的负担
    4. 适合在生产者线程和消费者线程之间的并发程序较高的情况下使用
  3. SynchronousQueue
    1. 可以被看做一种特殊的有界队列
    2. 生产者线程生产一个产品之后,会等待消费者线程来取走这个产品,才会接着生产下一个产品
    3. 适合在生产者线程和消费者线程之间的处理能力相差不大的情况下使用
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值