HashMap详解

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

wKioL1SDKp_za0wvAAIJCY9fhVI454.jpg

Map的遍历分2种:

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

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


下面给出map几种遍历方法:

import java.util.*;
import java.util.Map.Entry;
/**
 * map集合和set集合一样是(元素存放)无序的 
 */
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(现获取key,再由key获得value值)		
		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("**********************");
			
		//方法二(法一的简便写法,熟练掌握foreach的用法)		
		for(String key : map.keySet()){
			System.out.println(key+"="+map.get(key));
		}		
		System.out.println("**********************");
		
		//方法三(推荐使用该方法遍历map集合,尤其是容量大时)		 
		for(Map.Entry<String, String> entry : map.entrySet()){
		      //map.entrySet()中存放键值对的对象,通过getKey()获得key,getValue()获得value
			System.out.println(entry.getKey()+"="+entry.getValue());
		}				
		System.out.println("**********************");
		
		//方法四	
		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(" ");	
		// 键(key)代表着单词,值(value)代表着次数
		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中,存在该元素,则将其值累加			
				map.put(arr[i],map.get(arr[i])+1 );
			}
		}		
		System.out.println("统计单词出现的个数,结果如下:");
		/*  for(String key : map.keySet()){
		*	 System.out.println(key+"="+map.get(key));
		 */ }
		 //下面解法稍微复杂些,为了更好的理解迭代器Iterator
		Set<String> set = map.keySet();
		//注意Iterator中for循环的写法
		for (Iterator<String> it = set.iterator(); it.hasNext();) {
		        //由Collection接口派生的两个接口是List和Set,遍历Collection中的每一个元素使用iterator()的方法
			//iterator()方法返回一个迭代子iit,使用该迭代子即可逐一访问集合中每一个元素
			String key = it.next();
			Integer value = map.get(key);//get(key)返回value值
			System.out.println(key + "=" + value);
		}
	}
}

运行结果如图所示:

wKioL1SDI0jxlSZQAADliY6xVpo686.jpg

提供一道有关HashMap的实例http://macxiao.blog.51cto.com/9606147/1586998

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

你可能感兴趣的:(HashMap)