⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 semaphoreboundedbuffer.java

📁 java concurrency in practice 源码. JAVA并发设计
💻 JAVA
字号:
package net.jcip.examples;import java.util.concurrent.*;import net.jcip.annotations.*;/** * BoundedBuffer * <p/> * Bounded buffer using \Semaphore * * @author Brian Goetz and Tim Peierls */@ThreadSafepublic class SemaphoreBoundedBuffer <E> {    private final Semaphore availableItems, availableSpaces;    @GuardedBy("this") private final E[] items;    @GuardedBy("this") private int putPosition = 0, takePosition = 0;    public SemaphoreBoundedBuffer(int capacity) {        if (capacity <= 0)            throw new IllegalArgumentException();        availableItems = new Semaphore(0);        availableSpaces = new Semaphore(capacity);        items = (E[]) new Object[capacity];    }    public boolean isEmpty() {        return availableItems.availablePermits() == 0;    }    public boolean isFull() {        return availableSpaces.availablePermits() == 0;    }    public void put(E x) throws InterruptedException {        availableSpaces.acquire();        doInsert(x);        availableItems.release();    }    public E take() throws InterruptedException {        availableItems.acquire();        E item = doExtract();        availableSpaces.release();        return item;    }    private synchronized void doInsert(E x) {        int i = putPosition;        items[i] = x;        putPosition = (++i == items.length) ? 0 : i;    }    private synchronized E doExtract() {        int i = takePosition;        E x = items[i];        items[i] = null;        takePosition = (++i == items.length) ? 0 : i;        return x;    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -