JAvaにおけるMap集合の一般的な遍歴方法及びHashMapの応用例

3773 ワード

Mapの遍歴は大体3種類あります.
1、Map.entrySet():各要素はMap.Entryオブジェクトであり、このオブジェクトでは、
置かれているのはMapの中のkey-valueのペアです.
2、遍歴Map.keySet():これはMapのkey値の集合であり、この集合を遍歴することによって
Mapの要素を読み込みます.
3、遍歴Map.values():それはMapの中のvalueの集合で、私達は直接この集合を通じて遍歴することができます
Mapの値は、keyを読み込めません.
 
package com.sort;



import java.util.HashMap;

import java.util.Iterator;

import java.util.Map;

import java.util.Set;

import java.util.Map.Entry;



/**

 * map   set        

 * map           

 * @author Owner

 *

 */

public class MapTest5 {



	public static void main(String[] args) {

		

		Map<String, String> map = new HashMap<String, String>();

		

		map.put("a", "zhangsan");

		map.put("b", "lisi");

		map.put("c", "wangwu");

		

//		System.out.println(map);

		

		/**

		 *      map

		 */

		Set<String> keySet = map.keySet();

		

		for(Iterator<String> iterator = keySet.iterator();iterator.hasNext();){

			String key = iterator.next();

			

			String value = map.get(key);

			

			System.out.println(key+"="+value);

		}

		

		System.out.println("**********************");

		

		/**

		 *      map

		 */

		for(String key : map.keySet()){

			System.out.println(key+"="+map.get(key));

		}

		

		System.out.println("**********************");

		

		/**

		 *      map,         map  ,       

		 */

		for(Map.Entry<String, String> entry : map.entrySet()){

			System.out.println(entry.getKey()+"="+entry.getValue());

		}

		

		

		System.out.println("**********************");

		

		/**

		 *      map

		 */

		Set<Entry<String, String>> entrySet = map.entrySet();

		

		for(Iterator<Map.Entry<String, String>> iterator = entrySet.iterator();iterator.hasNext();){

			Map.Entry<String, String> entry = iterator.next();

			

			System.out.println(entry.getKey()+"="+entry.getValue());

		}

		

		

		System.out.println("**********************");

		/**

		 *    ,            

		 */

		for(String value : map.values()){

			System.out.println(value);

		}

		

	}

}


 
Mapの要素の格納は無秩序です
HashMapの注意事項:
1,HashMapの下部には配列が維持され、私たちがHashMapに配置したオブジェクトは実際にはその配列に格納されています.
2.HashMap内のputのキー値のペアに対して、keyのhashCode値に基づいて、オブジェクトが配列に格納されるように準備されている位置を計算します.
HashMap応用例:コンソールは英語を入力し、各単語の出現回数を簡単に統計する.
 
package com.sort;



import java.util.HashMap;

import java.util.Iterator;

import java.util.Map;

import java.util.Scanner;

import java.util.Set;



/**

 *                     

 * 

 * @author Owner

 * 

 */

public class MapTest3 {



	public static void main(String[] args) {

		

		Scanner sc = new Scanner(System.in);

		

		System.out.println("       ,        :");

		

		String sentence = sc.nextLine();

		

		String[] arr = sentence.split(" ");

		

		//       ,      

		Map<String, Integer> map = new HashMap<String, Integer>();

		for (int i = 0; i < arr.length; i++) {

			if (!map.containsKey(arr[i])) {

				map.put(arr[i], 1);

			} else {

				//   map ,     

				int num = map.get(arr[i]);

				map.put(arr[i], ++num);

			}

		}

		

		System.out.println("         ,    :");



		Set<String> set = map.keySet();



		for (Iterator<String> iterator = set.iterator(); iterator.hasNext();) {

			String key = iterator.next();



			Integer value = map.get(key);



			System.out.println(key + "=" + value);

		}

	}

}


 
出力結果:
単語間をスペースで区切った英語を入力してください:I love U China I am pround to be a Chinese単語の出現個数を統計して、結果は以下の通りです:to=1 U=1 love=1 am=1 a=1 pround=1 Chinese=1 I=2 China=1 be=1