并发()——SynchronousQueue源码解析

在这里插入图片描述

概述

SynchronousQueue 实际上不是一个真正的队列,因为它不会为队列中的元素维护存储空间。与其他队列不同的是,它维护一组线程,这些线程在等待着把元素加入或移除队列。

SynchronousQueue不像ArrayBlockingQueue或者LinkedBlockingQueue,你不能调用peek()方法来看队列中是否有数据元素,因为数据元素只有当你试图取走的时候才可能存在,不取走而只想看一下是否有数据是不可以的。队列的头元素是第一个要输入数据的线程,而不是要交换的数据。数据是在配对的生产者与消费者之间直接传递,并不会将数据缓冲到队列中。

SynchronousQueue的应用场景

Executors.newCachedThreadPool() 就是使用了 SynchronousQueue,即SynchronousQueue作为newCachedThreadPool的工作队列(workQueue)。这个线程池在新任务到来时需要创建新的线程,如果有空闲线程则会重复使用,线程空闲了60秒之后就会被回收。

SynchronousQueue的公平模式源码

SynchronousQueue内部是通过Transferer实现的,具体分为两个Transferer,分别是TransferStack和TransferQueue,两者的差别在于是否公平。

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值