189 8069 5689

ArrayBlockingQueue怎么在java中使用

ArrayBlockingQueue怎么在java中使用?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

十多年的新乡县网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。网络营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整新乡县建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联公司从事“新乡县网站设计”,“新乡县网站推广”以来,每个客户项目都认真落实执行。

Java是什么

Java是一门面向对象编程语言,可以编写桌面应用程序、Web应用程序、分布式系统和嵌入式系统应用程序。

1.入队流程

构造一个长度为 6 的环形数组:

(1)刚刚开始构造完毕时,插入索引和取出索引都在同一个位置,数组内值为空

(2)将元素 A 进行入队操作。元素 A 入队后,取出值的索引不会变化,但是入队索引会偏移到下一个位置

(3)继续进行入队操作,直到 putIndex 索引指向最后一个位置

(4)将元素 F 进行入队,我们会看到,putIndex 索引和 takeIndex 索引,又到回了初始时的位置,这就是上面说的环形队列,此时如果再有线程进行入队操作时,线程便会堵塞,直到元素被消费。

2.入队方法

入队有四个方法,它们分别是add、offer、put、offer,就其中两种带来介绍。

(1)add 方法

//添加元素到队尾
public boolean add(E e) {
        //调用父类的方法
        return super.add(e);
    }
//父类的添加方法
 public boolean add(E e) {
        //实质是调用offer方法
        if (offer(e))
            return true;
        else
            throw new IllegalStateException("Queue full");
    }

(2)put 方法

//添加制定元素到队尾,如果队列满了一直等待队列有元素出队
public void put(E e) throws InterruptedException {
        checkNotNull(e);
        //上锁
        final ReentrantLock lock = this.lock;
        lock.lockInterruptibly();
        try {
            while (count == items.length)
                //while循环,如果队列满了一直等待
                notFull.await();
            //队列还有空间,调用enqueue方法入队
            enqueue(e);
        } finally {
            //释放锁资源
            lock.unlock();
        }
}

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。


分享名称:ArrayBlockingQueue怎么在java中使用
文章转载:http://cdxtjz.com/article/jdeipd.html

其他资讯