设为首页收藏本站

安徽论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 78827|回复: 0

Java BlockingQueue阻塞队列是线程安全的吗 是线程安全的

[复制链接]

110

主题

0

回帖

342

积分

中级会员

Rank: 3Rank: 3

积分
342
发表于 2022-3-26 10:29:49 | 显示全部楼层 |阅读模式
网站内容均来自网络,本站只提供信息平台,如有侵权请联系删除,谢谢!
welcome to my blog

问题描述 Java BlockingQueue 阻塞队列的take()和put()方法是线程安全的吗? 多线程下调用take()或者put()方法会出问题吗?

看了BlockingQueue的三个实现类, 发现对应的方法中都使用了锁, 所以不会出现线程安全问题

ArrayBlockingQueue

  1.         //ArrayBlockingQueue的put()方法    public void put(E e) throws InterruptedException {        Objects.requireNonNull(e);        final ReentrantLock lock = this.lock;        //获取锁        lock.lockInterruptibly();        try {            while (count == items.length)                    //队列满了, 进入阻塞状态                 notFull.await();            enqueue(e);        } finally {            //释放锁            lock.unlock();        }    }//ArrayBlockingQueue的take()方法    public E take() throws InterruptedException {        final ReentrantLock lock = this.lock;        //获取锁        lock.lockInterruptibly();        try {            while (count == 0)                    //队列为空,进入阻塞状态                notEmpty.await();            //弹出元素            return dequeue();        } finally {                //释放锁            lock.unlock();        }    }
复制代码
LinkedBlockingQueue

  1.         //LinkedBlockingQueue的put()方法    public void put(E e) throws InterruptedException {        if (e == null) throw new NullPointerException();        final int c;        final Node node = new Node(e);        final ReentrantLock putLock = this.putLock;        final AtomicInteger count = this.count;        //获取锁        putLock.lockInterruptibly();        try {            /*             * Note that count is used in wait guard even though it is             * not protected by lock. This works because count can             * only decrease at this point (all other puts are shut             * out by lock), and we (or some other waiting put) are             * signalled if it ever changes from capacity. Similarly             * for all other uses of count in other wait guards.             */            while (count.get() == capacity) {                notFull.await();            }            //元素入队            enqueue(node);            c = count.getAndIncrement();            if (c + 1 < capacity)                notFull.signal();        } finally {                //释放锁            putLock.unlock();        }        if (c == 0)            signalNotEmpty();    }        //LinkedBlockingQueue的take()方法    public E take() throws InterruptedException {        final E x;        final int c;        final AtomicInteger count = this.count;        final ReentrantLock takeLock = this.takeLock;        //获取锁        takeLock.lockInterruptibly();        try {            while (count.get() == 0) {                notEmpty.await();            }            x = dequeue();            c = count.getAndDecrement();            if (c > 1)                notEmpty.signal();        } finally {                //释放锁            takeLock.unlock();        }        if (c == capacity)            signalNotFull();        return x;    }
复制代码
PriorityBlockingQueue

[code]//PriorityBlockingQueue的put()方法public void put(E e) {                //锁的操作在offer()方法中        offer(e); // never need to block    }//PriorityBlockingQueue的offer()方法public boolean offer(E e) {        if (e == null)            throw new NullPointerException();        final ReentrantLock lock = this.lock;        //获取锁        lock.lock();        int n, cap;        Object[] es;        while ((n = size) >= (cap = (es = queue).length))            tryGrow(es, cap);        try {            final Comparator
免责声明
1. 本论坛所提供的信息均来自网络,本网站只提供平台服务,所有账号发表的言论与本网站无关。
2. 其他单位或个人在使用、转载或引用本文时,必须事先获得该帖子作者和本人的同意。
3. 本帖部分内容转载自其他媒体,但并不代表本人赞同其观点和对其真实性负责。
4. 如有侵权,请立即联系,本网站将及时删除相关内容。
懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表