ホームページ >Java >&#&チュートリアル >Java でブロッキング キューを実装するために「wait()」と「notify()」をどのように使用できますか?
マルチスレッド プログラミングでは、wait() と Notify() は次のとおりです。スレッドの同期に使用されます。この記事では、wait() と Notice() を使用してブロッキング キューを実装する方法について説明します。ブロッキング キューは、項目が使用可能になるかスペースが使用可能になるまでスレッドをブロックできるようにするデータ構造です。
の条件ブロック:
Java コード:
public class BlockingQueue<T> { private Queue<T> queue = new LinkedList<>(); private int capacity; public BlockingQueue(int capacity) { this.capacity = capacity; } public synchronized void put(T element) throws InterruptedException { while (queue.size() == capacity) { wait(); } queue.add(element); notify(); // notifyAll() for multiple producer/consumer threads } public synchronized T take() throws InterruptedException { while (queue.isEmpty()) { wait(); } T item = queue.remove(); notify(); // notifyAll() for multiple producer/consumer threads return item; } }
Java 1.5 では、より高いレベルを提供する同時実行ライブラリが導入されました。抽象化:
変更されたブロッキング キューの実装:
public class BlockingQueue<T> { private Queue<T> queue = new LinkedList<>(); private int capacity; private Lock lock = new ReentrantLock(); private Condition notFull = lock.newCondition(); private Condition notEmpty = lock.newCondition(); public BlockingQueue(int capacity) { this.capacity = capacity; } public void put(T element) throws InterruptedException { lock.lock(); try { while (queue.size() == capacity) { notFull.await(); } queue.add(element); notEmpty.signal(); } finally { lock.unlock(); } } public T take() throws InterruptedException { lock.lock(); try { while (queue.isEmpty()) { notEmpty.await(); } T item = queue.remove(); notFull.signal(); return item; } finally { lock.unlock(); } } }
以上がJava でブロッキング キューを実装するために「wait()」と「notify()」をどのように使用できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。