借助“有界队列”理解 Condition 的使用方式

1、

package multiThread.art;

import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

/**
 * 借助“有界队列”理解 Condition 的使用方式
 *
 * 有界队列:是一种特殊的队列,当队列为空的时候,队列的获取操作将会阻塞获取线程,
 *          直到队列中有新增元素,当队列已经满了的时候,队列的插入将会阻塞插入线程,
 *          直到队列出现“空位”
 *
 *  补充: 在添加和删除方法中使用 “while 循环”而非“if 判断 ”,
 *        目的是防止过早或者意外的通知,只有条件符合才能退出循环。
 */
public class BoundedQueue<T> {
    private Object[] items;
    /**
     * 添加的下标,删除的下标,数组当前的数量
     */
    private int addIndex , removeIndex , count;
    private Lock lock = new ReentrantLock();
    Condition notEmpty = lock.newCondition();
    Condition notFull = lock.newCondition();

    /**
     * 添加一个元素,如果数组满了,则添加线程进入等待状态,直到有“空位”
     */
    public void add(T t) throws InterruptedException {
        lock.lock();
        try{
            while( count == items.length){
                notFull.await();
            }
            items[addIndex] = t;
            if( ++ addIndex == items.length ){
                addIndex = 0;
            }
            ++count;
            notEmpty.signal();
        }finally {
            lock.unlock();
        }
    }
    /**
     *  由头部删除一个元素,如果数组空,则删除线程进入等待状态,直到有新添加元素
     */
    public T remove() throws InterruptedException {
        lock.lock();
        try{
            while( count == 0 ){
                notEmpty.await();
            }
            Object x = items[removeIndex];
            if( ++ removeIndex == items.length){
                removeIndex = 0;
            }
            --count;
            notFull.signal();
            return (T) x;
        }finally {
            lock.unlock();
        }
    }

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小达人Fighting

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值