首页 > 代码库 > HashMap详解
HashMap详解
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
HashMap详解
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。