Java 8は、java.util.stream
パッケージにあるストリームを導入します。ストリームは、配列やコレクションに似た一連のオブジェクトであり、フィルタリング、マッピング、削減、一致、統合など、さまざまな方法と集約操作をサポートしています。 これらの操作は、元のデータソースを変更するのではなく、処理用の新しいストリームを作成します。ストリームは、主にシーケンシャルストリームとパラレルストリームの2つのタイプに分割されます。この記事では、2つの違いに焦点を当てます。
シーケンシャルストリームとは何ですか?
シーケンシャルストリームは、単一のスレッドを使用して、パイプラインのデータを処理します。シーケンシャルストリームのオブジェクトは同じ処理システムに配置され、順番に配置されるため、マルチコアシステムを使用して処理されません。
平行ストリームとは何ですか?
並列ストリームは、マルチコアプロセッサを利用してプログラムのパフォーマンスを向上させます。コードは、異なるカーネルで並行して実行される並列ストリームメソッドを介して複数のストリームに分割されます。最終結果は、マージ後に表示されます。実行者は実行者によって制御されていないため、結果は乱れている可能性があります。平行なフローは、次の方法で使用できます。
- インターフェイスには、並列ストリームを作成するための
Collection
メソッドが含まれています。 parallelStream()
- インターフェイスには、シーケンシャルストリームをパラレルストリームに変換するために使用できる
BaseStream
メソッドが含まれています。 parallel()
順次流れと平行流の違い
次の表は、Javaのシーケンシャルストリームと平行ストリームの主な違いをまとめたものです。
結論
Javaのストリームは、主に連続ストリームと平行ストリームに分割されています。シーケンシャルストリームは、コンピューターの単一のカーネルを使用して実行され、パフォーマンスが遅いが、プラットフォーム関連ではなく、整然とした結果でオブジェクトを順番に実行します。パラレルストリームは、コンピューターの複数のコアを使用して実行され、パフォーマンスは高速ですが、結果は順調です。
シーケンシャルおよびパラレルストリームFAQ
1。
シーケンシャルストリーミングは、コードを実行するために単一のカーネルのみを使用するため、プラットフォーム関連です。パラレルストリームは複数のカーネルを使用してコードを実行するため、プラットフォームに依存します。
2エラーが発生しやすいですか?
並列ストリームは、コンピューターの複数のコアで実行され、結果が順調になっているため、エラーが発生しやすくなります。シーケンシャルストリーミングエラーの確率は、単一のカーネルのみを使用してコードを実行するため、低くなります。
3。
連続ストリームでは、一度に1つの反復のみを実行できます。次の反復は、現在の反復が完了するのを待つ必要があります。並列ストリームでは、反復は異なるカーネルで同時に機能します。すべてのカーネルがビジーである場合、反復は待たなければなりません。
4
シーケンシャルストリームは、実行中は1つのカーネルのみを使用しているため、実行中は順番に残ります。各反復は、現在の反復が実行を完了するのを待つ必要があります。
5。
パラレルストリーミングは、複数のコアを使用して実行されるため、より速く実行されます。シーケンシャルストリームは1つのコアのみを使用するため、パフォーマンスが低下します。
以上がJavaの並列ストリームとシーケンシャルストリームの違いの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。