文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

linkedblockingqueue如何在java中使用

2023-06-14 17:54

关注

本篇文章为大家展示了linkedblockingqueue如何在java中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

Java的特点有哪些

Java的特点有哪些1.Java语言作为静态面向对象编程语言的代表,实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。2.Java具有简单性、面向对象、分布式、安全性、平台独立与可移植性、动态性等特点。3.使用Java可以编写桌面应用程序、Web应用程序、分布式系统和嵌入式系统应用程序等。

1.put方法使用事项

(1)使用putLock加锁;

(2)如果队列满了就阻塞在notFull条件上;

(3)否则就入队;

(4)如果入队后元素数量小于容量,唤醒其它阻塞在notFull条件上的线程;

(5)释放锁;

(6)如果放元素之前队列长度为0,就唤醒notEmpty条件;

2.put增加元素实例

 public void put(E e) throws InterruptedException {        if (e == null) throw new NullPointerException();   //e不能为null        int c = -1;        Node<E> node = new Node<E>(e);        final ReentrantLock putLock = this.putLock;     //获取put锁        final AtomicInteger count = this.count;          //获取count        putLock.lockInterruptibly();        try {            while (count.get() == capacity) {        //如果满了,那么就需要使用notFull阻塞                notFull.await();            }            enqueue(node);            c = count.getAndIncrement();            if (c + 1 < capacity)                    //如果此时又有空间了,那么notFull唤醒                notFull.signal();        } finally {            putLock.unlock();             //释放锁        }        if (c == 0)            //当c为0时候,也要根take锁说一下,并发下            signalNotEmpty();        //调用notEmpty            }public E take() throws InterruptedException {    E x;    int c = -1;    final AtomicInteger count = this.count;    final ReentrantLock takeLock = this.takeLock;    // 使用takeLock加锁    takeLock.lockInterruptibly();    try {        // 如果队列无元素,则阻塞在notEmpty条件上        while (count.get() == 0) {            notEmpty.await();        }        // 否则,出队        x = dequeue();        // 获取出队前队列的长度        c = count.getAndDecrement();        // 如果取之前队列长度大于1,则唤醒notEmpty        if (c > 1)            notEmpty.signal();    } finally {        // 释放锁        takeLock.unlock();    }    // 如果取之前队列长度等于容量    // 则唤醒notFull    if (c == capacity)        signalNotFull();    return x;} private E dequeue() {    // head节点本身是不存储任何元素的    // 这里把head删除,并把head下一个节点作为新的值    // 并把其值置空,返回原来的值    Node<E> h = head;    Node<E> first = h.next;    h.next = h; // help GC    head = first;    E x = first.item;    first.item = null;    return x;} private void signalNotFull() {    final ReentrantLock putLock = this.putLock;    putLock.lock();    try {        // 唤醒notFull        notFull.signal();    } finally {        putLock.unlock();    }}

上述内容就是linkedblockingqueue如何在java中使用,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯