java集合类中常见的Map类型HashMap的常用方法
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);
}
}
}运行结果如图所示:
本文出自 “闲庭信步、” 博客,请务必保留此出处http://macxiao.blog.51cto.com/9606147/1587211
原文:http://macxiao.blog.51cto.com/9606147/1587211