ホームページ > バックエンド開発 > Golang > 複数のブロッキングキューから効率的に読み取るための Go の「select」に相当する Java はありますか?

複数のブロッキングキューから効率的に読み取るための Go の「select」に相当する Java はありますか?

Barbara Streisand
リリース: 2024-12-18 20:21:11
オリジナル
192 人が閲覧しました

Is There a Java Equivalent to Go's `select` for Efficiently Reading from Multiple Blocking Queues?

Java の Go チャネルに相当

質問:

データを効率的に読み取る必要があります個別のリーダー スレッドを作成せずに、複数のブロッキング キューから読み取ります。 Java には Go の select/epoll と同等のメカニズムがありますか?

回答:

Alternative クラスを提供する JCSP ライブラリの使用を検討してください。 Alternative は Go の select ステートメントに相当します。これにより、継続的なポーリングを必要とせずに、複数のソース チャネルからのデータを多重化できる単一のコンシューマ スレッドを作成できます。

JCSP 代替の利点:

  • 公平な多重化: 代替手段は、データ消費の公平性を保証し、入力チャネルが多重化されるのを防ぎます。
  • デッドロックからの解放: JCSP チャネルと代替は正式に検証されており、信頼性が高く、デッドロックに耐性があります。

使用例:

次の Java コードは、以下を使用して公平なマルチプレクサを示します。 JCSP:

import org.jcsp.lang.*;

public class FairPlex implements CSProcess {

    private final AltingChannelInput[] in;
    private final ChannelOutput out;

    public FairPlex (final AltingChannelInput[] in, final ChannelOutput out) {
      this.in = in;
      this.out = out;
    }

    public void run () {

      final Alternative alt = new Alternative (in);

      while (true) {
        final int index = alt.fairSelect ();
        out.write (in[index].read ());
      }
    }
 }
ログイン後にコピー

追加メモ:

JCSP Web サイトに記載されている内容とは異なり、Maven リポジトリ内の JCSP の現在のバージョンは 1.1-rc5 です。

以上が複数のブロッキングキューから効率的に読み取るための Go の「select」に相当する Java はありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート