首页 > 代码库 > HashMap详解

HashMap详解

java集合类中常见的Map类型HashMap的常用方法

wKioL1SDKp_za0wvAAIJCY9fhVI454.jpg

Map的遍历分2种:

1、(推荐)遍历Map.entrySet():它的每一个元素都是Map.Entry对象,这个对象中,放着的就是Map中的某一对key-value;

2、遍历Map.keySet():它是Map中key值的集合,我们可以通过遍历这个集合来读取Map中的元素;

import java.util.*;
import java.util.Map.Entry;
/**
 * map集合和set集合一样是(元素存放)无序的
 * map集合遍历的几种常用方法
 */
public class MapTest{
	public static void main(String[] args) {		
		Map<String, String> map = new HashMap<String, String>();
		//小技巧:将所有Map变量声明为Map,而不是任何具体实现,可获得最佳map性能
		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);
		}
		
	}
}

下面给出一hashmap遍历的简单实例:

import java.util.*;
/**
 * 统计一句英语的简单统计各个单词出现的次数
 */
public class MapTest{
	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])) {
			        //第一次出现时将其值设为1
				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);//get(key)返回value值
			System.out.println(key + "=" + value);
		}
	}
}

运行结果如图所示:

wKioL1SDI0jxlSZQAADliY6xVpo686.jpg


宠辱不惊,闲看庭前花开花落;去留无意,漫随天外云卷云舒。 j_0003.gif

本文出自 “闲庭信步、” 博客,请务必保留此出处http://macxiao.blog.51cto.com/9606147/1587211

HashMap详解