java集合类中常见的Map类型HashMap的常用方法
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); } } }
运行结果如图所示:
提供一道有关HashMap的实例http://macxiao.blog.51cto.com/9606147/1586998