java队列课程_java常见队列及应用详解

1. java常见队列:

(1) ArrayBlockingQueue:

一个基于数组结构的有界阻塞队列, FIFO(先进先出)。

(2) LinkedBlockingQueue:

一个基于链表结构的阻塞队列, 此队列按FIFO (先进先出) 排序元素,

吞吐量通常要高于ArrayBlockingQueue,

静态工厂方法 Executors.newFixedThreadPool() 使用了这个队列。

(3) SynchronousQueue:

一个不存储元素的阻塞队列。

每个插入操作必须等到另一个线程调用移除操作,

否则插入操作一直处于阻塞状态,

吞吐量通常要高于LinkedBlockingQueue, 静态工厂方法 Executors.newCachedThreadPool() 使用了这个队列。

(4) PriorityBlockingQueue:

一个具有优先级的无限阻塞队列。

2.  LinkedBlockingQueue使用示例

public final static BlockingQueue DATA_QUEUE = new LinkedBlockingQueue<>();

// 向队列中插入消息

public void upsertClinicStructData(JSONObject paramJson) {

try {

CLINIC_DATA_QUEUE.put(paramJson);

} catch (InterruptedException e) {

log.warn(CLINIC_DATA_QUEUE + " 队列保存数据异常! paramJson: " + paramJson, e);

}

}

/**

* 消费队列数据

*/

public void consmrClinicDataQueue() {

List list = Lists.newArrayList();

DATA_QUEUE.drainTo(list, 1000);

if (list.size() < 1) {

log.debug(DATA_QUEUE + "队列元素为空");

return;

}

log.info("从队列取出数据数目: " + list.size());

// list处理逻辑

...

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值