使用显示条件变量的有界缓存

通过使用reetrantlock和condition实现的有界缓存。

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

/**
 * Created by hybian on 2017/4/18.
 */

public class ConditionBoundedBuffer<T> {
    private int tail, head, count;
    private final int BUFFER_SIZE;
    private final T[] items;
    protected final Lock lock = new ReentrantLock();
    //条件谓词
    private final Condition notFull = lock.newCondition();
    private final Condition notEmpty = lock.newCondition();
    public ConditionBoundedBuffer(int buffer_size) {
        this.BUFFER_SIZE = buffer_size;
        items = (T[])new Object[BUFFER_SIZE];
    }
    //阻塞直到notFull
    public void put(T x) throws InterruptedException {
        lock.lockInterruptibly();
        try {
            while (count == items.length)
                notFull.await();
            items[tail] = x;
            if (++tail == items.length)
                tail = 0;
            ++count;
            notEmpty.signal();
        }finally {
            lock.unlock();
        }
    }
    public T take() throws InterruptedException {
        lock.lockInterruptibly();
        try {
            while (count == 0)
                notEmpty.await();
            T x = items[head];
            items[head] = null;
            if (++head == items.length)
                head = 0;
            --count;
            notFull.signal();
            return x;
        }finally {
            lock.unlock();
        }
    }
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容