一般的にはあります 五 を反復する方法 地図 ジャワでは。この記事では、それらすべてについて説明し、それぞれの長所と短所についても見ていきます。
まず第一に、私たちは できない を使用してマップを直接反復します イテレータ 、マップはそうではないので、 コレクション。 また、先に進む前に、次のことについて少し知っておく必要があります。 マップ.エントリ インターフェース。
Java のすべてのマップは実装されているため、 地図 インターフェイスでは、次のテクニックはあらゆるマップ実装 ( HashMap 、 TreeMap 、 LinkedHashMap 、 Hashtable など) で機能します。
1. For-Each ループを使用して Map.entrySet() を反復します。
Map.entrySet() メソッドはコレクションビュー( セット
ジャワ
ターミナルカリLinux
// Java program to demonstrate iteration over> // Map.entrySet() entries using for-each loop> > import> java.util.Map;> import> java.util.HashMap;> > class> IterationDemo> {> > public> static> void> main(String[] arg)> > {> > Map gfg => new> HashMap();> > > // enter name/url pair> > gfg.put(> 'GFG'> ,> 'techcodeview.com'> );> > gfg.put(> 'Practice'> ,> 'practice .techcodeview.com> );> > gfg.put(> 'Code'> ,> 'code .techcodeview.com> );> > gfg.put(> 'Quiz'> ,> 'www .techcodeview.com> );> > > // using for-each loop for iteration over Map.entrySet()> > for> (Map.Entry entry : gfg.entrySet())> > System.out.println(> 'Key = '> + entry.getKey() +> > ', Value = '> + entry.getValue());> > }> }> |
>
>
出力:
Key = Quiz, Value = www.techcodeview.com Key = Practice, Value = practice.techcodeview.com Key = GFG, Value = techcodeview.com Key = Code, Value = code.techcodeview.com>
2. keySet() メソッドと value() メソッドを使用したキーまたは値の反復処理
Map.keySet() メソッドは、このマップに含まれるキーの Set ビューを返します。 Map.values() メソッドは、このマップに含まれる値のコレクション ビューを返します。したがって、マップのキーまたは値のみが必要な場合は、for-each ループを使用して keySet または値を反復処理できます。以下はそれを示す Java プログラムです。
ジャワ
// Java program to demonstrate iteration over> // Map using keySet() and values() methods> > import> java.util.Map;> import> java.util.HashMap;> > class> IterationDemo> {> > public> static> void> main(String[] arg)> > {> > Map gfg => new> HashMap();> > > // enter name/url pair> > gfg.put(> 'GFG'> ,> 'techcodeview.com'> );> > gfg.put(> 'Practice'> ,> 'practice .techcodeview.com> );> > gfg.put(> 'Code'> ,> 'code .techcodeview.com> );> > gfg.put(> 'Quiz'> ,> 'www .techcodeview.com> );> > > // using keySet() for iteration over keys> > for> (String name : gfg.keySet())> > System.out.println(> 'key: '> + name);> > > // using values() for iteration over values> > for> (String url : gfg.values())> > System.out.println(> 'value: '> + url);> > }> }> |
>
>
出力:
key: Quiz key: Practice key: GFG key: Code value: www.techcodeview.com value: practice.techcodeview.com value: techcodeview.com value: code.techcodeview.com>
3. イテレータを使用した反復処理 マップ.エントリ
この方法は最初の方法と多少似ています。最初の方法では Map.Entry に対して for-each ループを使用しますが、ここでは イテレータ 。 Map.Entry 上でイテレータを使用することには、それ自体の利点があります。を呼び出すことで、反復中にマップからエントリを削除できます。 iterator.remove() 方法。
ジャワ
ブロックされた連絡先
// Java program to demonstrate iteration over> // Map using keySet() and values() methods> > import> java.util.Map;> import> java.util.HashMap;> import> java.util.Iterator;> > class> IterationDemo> {> > public> static> void> main(String[] arg)> > {> > Map gfg => new> HashMap();> > > // enter name/url pair> > gfg.put(> 'GFG'> ,> 'techcodeview.com'> );> > gfg.put(> 'Practice'> ,> 'practice .techcodeview.com> );> > gfg.put(> 'Code'> ,> 'code .techcodeview.com> );> > gfg.put(> 'Quiz'> ,> 'www .techcodeview.com> );> > > // using iterators> > Iterator itr = gfg.entrySet().iterator();> > > while> (itr.hasNext())> > {> > Map.Entry entry = itr.next();> > System.out.println(> 'Key = '> + entry.getKey() +> > ', Value = '> + entry.getValue());> > }> > }> }> |
>
>
出力:
Key = Quiz, Value = www.techcodeview.com Key = Practice, Value = practice.techcodeview.com Key = GFG, Value = techcodeview.com Key = Code, Value = code.techcodeview.com>
4. forEach(action) メソッドの使用:
Java 8 では、次を使用してマップを反復できます。 Map.forEach(アクション) 方法と使い方 ラムダ式 。このテクニックはクリーンで高速です。
ジャワ
// Java code illustrating iteration> // over map using forEach(action) method> > import> java.util.Map;> import> java.util.HashMap;> > class> IterationDemo> {> > public> static> void> main(String[] arg)> > {> > Map gfg => new> HashMap();> > > // enter name/url pair> > gfg.put(> 'GFG'> ,> 'techcodeview.com'> );> > gfg.put(> 'Practice'> ,> 'practice .techcodeview.com> );> > gfg.put(> 'Code'> ,> 'code .techcodeview.com> );> > gfg.put(> 'Quiz'> ,> 'www .techcodeview.com> );> > > // forEach(action) method to iterate map> > gfg.forEach((k,v) ->System.out.println(> 'Key = '> > + k +> ', Value = '> + v));> > > }> }> |
string.format Java文字列
>
>
Javaの配列リスト
出力:
Key = Quiz, Value = www.techcodeview.com Key = Practice, Value = practice.techcodeview.com Key = GFG, Value = techcodeview.com Key = Code, Value = code.techcodeview.com>
5. キーの反復処理と値の検索 (非効率)
ここではまずキーをループします(使用 Map.keySet() メソッド) を使用して値を検索します。 Map.get(キー) このメソッドは、キーによる値の取得に時間がかかる可能性があるため、非常に遅く非効率的であるため、実際には使用されません。
ジャワ
// Java program to demonstrate iteration> // over keys and searching for values> > import> java.util.Map;> import> java.util.HashMap;> > class> IterationDemo> {> > public> static> void> main(String[] arg)> > {> > Map gfg => new> HashMap();> > > // enter name/url pair> > gfg.put(> 'GFG'> ,> 'techcodeview.com'> );> > gfg.put(> 'Practice'> ,> 'practice .techcodeview.com> );> > gfg.put(> 'Code'> ,> 'code .techcodeview.com> );> > gfg.put(> 'Quiz'> ,> 'www .techcodeview.com> );> > > // looping over keys> > for> (String name : gfg.keySet())> > {> > // search for value> > String url = gfg.get(name);> > System.out.println(> 'Key = '> + name +> ', Value = '> + url);> > }> > }> }> |
>
>
出力:
Key = Quiz, Value = www.techcodeview.com Key = Practice, Value = practice.techcodeview.com Key = GFG, Value = techcodeview.com Key = Code, Value = code.techcodeview.com>
参考文献: スタックオーバーフロー