Java中的ArrayBlockingQueue

package org.example;

import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class ABQ {
    public static void main(String[] args) {
        ArrayBlockingQueue<Integer> abq = new ArrayBlockingQueue<Integer>(2);
        ExecutorService es = Executors.newFixedThreadPool(2);
        es.submit(() -> {
            for (int i = 0; i < 10; i++) {
                try {
                    abq.put(i);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                    System.exit(1);
                }
            }
        });
        es.submit(() -> {
            for (int i = 0; i < 10; i++) {
                try {
                    int v = abq.take();
                    System.out.println(v);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                    System.exit(1);
                }
            }
        });
        es.shutdown();
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaArrayBlockingQueue是一种基于数组的有界阻塞队列,它有固定大小,并且一旦创建就不能改变大小。它提供了先进先出的队列操作,并且支持阻塞队列的特性,即当队列为空时,队列的读取操作会被阻塞,直到有新的元素被添加到队列;当队列满时,队列的插入操作会被阻塞,直到有元素被取出队列。 以下是一些常用的操作: 1. 创建ArrayBlockingQueue对象: ```java ArrayBlockingQueue<Integer> queue = new ArrayBlockingQueue<Integer>(capacity); ``` 其,capacity指定了队列的大小。 2. 添加元素到队列: ```java queue.add(element);//当队列满时会抛出IllegalStateException异常 queue.offer(element);//当队列满时会返回false queue.put(element);//当队列满时会阻塞 ``` 3. 从队列取出元素: ```java queue.take();//当队列为空时会阻塞 queue.poll();//当队列为空时会返回null queue.poll(timeout, TimeUnit);//当队列为空时会等待一段时间,超时返回null ``` 4. 获取队列的元素个数: ```java queue.size(); ``` 5. 判断队列是否为空或已满: ```java queue.isEmpty(); queue.isFull();//ArrayBlockingQueue没有提供isFull方法,但可以通过判断size和capacity是否相等来实现 ``` 6. 循环遍历队列: ```java for (Integer i : queue) { // do something } ``` 注意:ArrayBlockingQueue是线程安全的,可以在多线程环境下使用,但需要注意使用同步措施,如锁或同步块等。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值