ホームページ Java &#&チュートリアル Java 同時プログラミングで LinkedBlockingQueue キューを使用する方法は?

Java 同時プログラミングで LinkedBlockingQueue キューを使用する方法は?

Apr 22, 2023 pm 02:31 PM
java linkedblockingqueue

LinkedBlockingQueue も一方向リンク リストを使用して実装されています。また、最初と最後のノードをそれぞれ格納するために使用される 2 つのノードがあり、初期値 0 のアトミック変数 count もあります。キュー要素の数を記録するために使用されます。また、ReentrantLock のインスタンスが 2 つあり、それぞれ要素の入力とキューからの要素のアトミック性を制御するために使用されます。このうち、takeLock は、1 つのスレッドだけが同時にキュー ヘッドから要素を取得でき、他のスレッドは取得する必要があることを制御するために使用されます。 PutLock は、同時に 1 つのスレッドだけがキュー ヘッドから要素を取得できるように制御します。1 つのスレッドがロックを取得して要素をキューの最後に追加でき、他のスレッドは待機する必要があります。さらに、notEmpty と notFull は条件変数であり、キューに出入りするときにブロックされるスレッドを格納するための内部条件キューがあります。実際、これはプロデューサー/コンシューマー モデルです。以下は排他ロックを作成するコードです。

private final AtomicInteger count = new AtomicInteger();

/** Lock held by take, poll, etc */
private final ReentrantLock takeLock = new ReentrantLock();

/** Wait queue for waiting takes */
private final Condition notEmpty = takeLock.newCondition();

/** Lock held by put, offer, etc */
private final ReentrantLock putLock = new ReentrantLock();

/** Wait queue for waiting puts */
private final Condition notFull = putLock.newCondition();
ログイン後にコピー
  • 呼び出し元のスレッドが LinkedBlockingQueue インスタンス上でテイクやポーリングなどの操作を実行するときは、1 つのスレッドだけがリンクされたインスタンスのヘッド ノードを操作できるようにするために、takeLock ロックを取得する必要があります。同時にリストアップします。さらに、条件変数 notEmpty 内の条件キューの維持には takeLock のロック状態管理メカニズムが使用されるため、呼び出しスレッドは notEmpty の await メソッドと signal メソッドを呼び出す前に、まず takeLock ロックを取得する必要があります。そうしないと、IllegalMonitorStateException 例外がスローされます。 。 NotEmpty は内部的に条件キューを保持しており、スレッドが takeLock を取得して notEmpty の await メソッドを呼び出すと、呼び出しスレッドはブロックされ、スレッドは notEmpty 内の条件キューに置かれ、スレッドが notEmpty を呼び出すまで待機します。方法。

  • LinkedBlockingQueue インスタンスで put や Offer などの操作を実行するときは、putLock ロックを取得して、1 つのスレッドだけがリンク リストの末尾ノードを同時に操作できるようにする必要があります。時間。同様に、条件変数 notFull 内の条件キューの維持には putLock のロック状態管理メカニズムが使用されるため、呼び出しスレッドは notFull の await メソッドと signal メソッドを呼び出す前に、まず putLock ロックを取得する必要があります。そうしないと、IllegalMonitorStateException 例外がスローされます。 NotFull は内部的に条件キューを保持します。スレッドが putLock ロックを取得して notFull の await メソッドを呼び出すと、呼び出しスレッドはブロックされ、スレッドは notFull 内の条件キューに置かれ、スレッドが notFull を呼び出すまで待機します。信号方式。以下は、LinkedBlockingQueue のパラメーターなしのコンストラクターのコードです。

次は LinkedBlockingQueue のパラメーターなしの構築コードです

public static final int MAX_VALUE = 0x7fffffff;
public LinkedBlockingQueue() {
    this(Integer.MAX_VALUE);
}


public LinkedBlockingQueue(int capacity) {
    if (capacity <= 0) throw new IllegalAgrumentException();
    this.capacity = capacity;
    last = head = new Node<E>(null);
}
ログイン後にコピー

このコードから、デフォルトのキュー容量が 0x7fffffff であることがわかり、ユーザーは指定することもできます容量自体が大きいため、ある程度、LinkedBlockingQueue は制限されたブロッキング キューであると言えます。

オファー操作

public boolean offer(E e) {
//(1)
    if (e == null) throw new NullPointerException();
    //(2)
    final AtomicInteger count = this.count;
    if (count.get() == capacity)
        return false;
        //(3)
    int c = -1;
    Node<E> node = new Node<E>(e);
    final ReentrantLock putLock = this.putLock;
    putLock.lock();
    try {
    //(4)
        if (count.get() < capacity) {
            enqueue(node);
            c = count.getAndIncrement();
            //(5)
            if (c + 1 < capacity)
                notFull.signal();
        }
    } finally {
    //(6)
        putLock.unlock();
    }
    //(7)
    if (c == 0)
        signalNotEmpty();
        //(8)
    return c >= 0;
}
ログイン後にコピー

コード (2) は、現在のキューがいっぱいかどうかを判断し、現在の要素を破棄して false を返します

コード (3) putLock ロックを取得すると、現在のスレッドがロックを取得した後、プットおよびオファー操作を呼び出す他のスレッドがブロックされます (ブロックされたスレッドは putLock ロックの AQS ブロッキング キューに配置されます)。

コード (4) は、現在のキューが満杯であるかどうかを再判断します。これは、コード (2) の実行およびオブジェクトの取得中に、他のスレッドが put または Offer 操作を通じてキューに新しい要素を追加した可能性があるためです。 putLock ロック。キューが実際にいっぱいではない場合、新しい要素がキューに追加され、カウンターが増分されます。

コード (5) は、新しい要素がキューに追加された後もキューに空き領域がある場合、notFull の await 操作が呼び出されるために notFull 条件付きキューが起動することを判断します (次のような場合)。 put メソッドが実行され、キューがいっぱいになります) キューが空になっているため、ブロックされたスレッドはキューに入れられたスレッドを事前にウェイクアップできます。

コード(6)は取得したputLockロックを解放しますが、tryブロックが例外をスローしてもfinallyが実行されるため、ロックの解放はfinallyで行う必要があることに注意してください。さらに、ロックが解放された後、put 操作の呼び出しによりブロックされた他のスレッドの 1 つがロックを取得します。コード (7) の

C0 は、コード (6) を実行してロックを解放するときに、キューに少なくとも 1 つの要素があることを示します。キューに要素がある場合、signalNotEmpty 操作が実行されます。 ##

以上がJava 同時プログラミングで LinkedBlockingQueue キューを使用する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Javaの平方根 Javaの平方根 Aug 30, 2024 pm 04:26 PM

Java の平方根のガイド。ここでは、Java で平方根がどのように機能するかを、例とそのコード実装をそれぞれ示して説明します。

Javaの完全数 Javaの完全数 Aug 30, 2024 pm 04:28 PM

Java における完全数のガイド。ここでは、定義、Java で完全数を確認する方法、コード実装の例について説明します。

Java の乱数ジェネレーター Java の乱数ジェネレーター Aug 30, 2024 pm 04:27 PM

Java の乱数ジェネレーターのガイド。ここでは、Java の関数について例を挙げて説明し、2 つの異なるジェネレーターについて例を挙げて説明します。

Javaのアームストロング数 Javaのアームストロング数 Aug 30, 2024 pm 04:26 PM

Java のアームストロング番号に関するガイド。ここでは、Java でのアームストロング数の概要とコードの一部について説明します。

ジャワのウェカ ジャワのウェカ Aug 30, 2024 pm 04:28 PM

Java の Weka へのガイド。ここでは、weka java の概要、使い方、プラットフォームの種類、利点について例を交えて説明します。

Javaのスミス番号 Javaのスミス番号 Aug 30, 2024 pm 04:28 PM

Java のスミス番号のガイド。ここでは定義、Java でスミス番号を確認する方法について説明します。コード実装の例。

Java Springのインタビューの質問 Java Springのインタビューの質問 Aug 30, 2024 pm 04:29 PM

この記事では、Java Spring の面接で最もよく聞かれる質問とその詳細な回答をまとめました。面接を突破できるように。

Java 8 Stream Foreachから休憩または戻ってきますか? Java 8 Stream Foreachから休憩または戻ってきますか? Feb 07, 2025 pm 12:09 PM

Java 8は、Stream APIを導入し、データ収集を処理する強力で表現力のある方法を提供します。ただし、ストリームを使用する際の一般的な質問は次のとおりです。 従来のループにより、早期の中断やリターンが可能になりますが、StreamのForeachメソッドはこの方法を直接サポートしていません。この記事では、理由を説明し、ストリーム処理システムに早期終了を実装するための代替方法を調査します。 さらに読み取り:JavaストリームAPIの改善 ストリームを理解してください Foreachメソッドは、ストリーム内の各要素で1つの操作を実行する端末操作です。その設計意図はです

See all articles