Java でのリストの反復: 総合ガイド
Java コレクションを操作する場合、リストを反復するさまざまなメソッドを理解することが重要です。以下に、最も一般的に使用される方法と、その利点および潜在的な欠点を示します。
Basic for Loop
for (int i = 0; i < list.size(); i++) { E element = list.get(i); }
このメソッドは、要素のインデックスへの直接アクセスを提供します。インデックスベースの操作に適しています。ただし、要素ごとに get() を呼び出すオーバーヘッドが発生する可能性があるため、効率的な反復にはお勧めできません。
拡張 for ループ
for (E element : list) { // Element operations }
この構文のショートカットは、内部的には反復子であり、リストの要素をループするためのより簡潔かつ効率的な方法を提供します。これは、単純な反復の場合に推奨される選択肢です。
Iterator
for (Iterator<E> iter = list.iterator(); iter.hasNext(); ) { E element = iter.next(); }
Iterator インターフェイスは反復を可能にし、反復中に要素を削除するための Remove() メソッドを提供します。拡張された for ループよりもパフォーマンスが若干低くなりますが、ループ内で項目を削除することもできます。
ListIterator
for (ListIterator<E> iter = list.listIterator(); iter.hasNext(); ) { E element = iter.next(); }
Iterator と同様に、 ListIterator インターフェイスは、add()、remove()、set() などの追加機能を提供し、実行中にリストを変更できるようにします。
関数型 Java
Java 8 では、ストリームを関数型変換に使用できます。
list.stream().map(e -> e + 1);
このアプローチにより、変換を適用できます。ストリーム内の各要素に対する関数ですが、要素のインデックスやリストへの直接アクセスは提供されません。
Iterable.forEach、Stream.forEach など。
Java 8 では、コレクションを反復処理し、提供された操作を各要素に適用する forEach などのメソッドが導入されています。
Arrays.asList(1, 2, 3, 4).forEach(System.out::println);
これらのメソッドは反復のための高レベルの抽象化を提供しますが、それほど効率的ではない可能性がありますまたは、前述した他の方法のように柔軟です。
以上がJava でリストを反復処理する最良の方法は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。