Map集合概述
Map 是一种键-值对(key-value)集合,Map 集合中的每一个元素都包含一个键对象和一个值对象。其中,键对象不允许重复,而值对象可以重复,并且值对象还可以是 Map 类型的,就像数组中的元素还可以是数组一样。
Map 接口主要有两个实现类:HashMap 类和 TreeMap 类。其中,HashMap 类按哈希算法来存取键对象,而 TreeMap 类可以对键对象进行排序。
一.map集合特点
1.map集合是以键值对形式
2.map集合遍历方式没有迭代器和foreach 因为map集合没有继承collection接口
遍历方式
通过Map.keySet遍历
通过foreach迭代entries,使用Map.entrySet遍历
package com.liaozhixiang.java; import java.util.HashMap; import java.util.Map; import java.util.Map.Entry; import java.util.Set; /** * Map集合特点 * 1.map集合是以键值对形式 * 2.map集合遍历方式没有迭代器和foreach 因为map集合没有继承collection接口 * * @author liao * */ public class Dome1 { @SuppressWarnings("unchecked") public static void main(String[] args) { HashMap map = new HashMap<>(); //增加 System.out.println("=====增加======="); map.put("id", 1); map.put("name", "zs"); map.put("age", 18); System.out.println(map); //删除 System.out.println("=======删除id属性==========="); Object remove = map.remove("id"); System.out.println(remove); System.out.println(map); //修改调用增加的方法并且覆盖原来的键值对 System.out.println("=====修改覆盖age 原18 修改后 33========="); map.put("age", 33); System.out.println(map); //查询 根据键拿到值 System.out.println("=======查询age属性==========="); System.out.println(map.get("age")); /** * 遍历方式 * 两种 */ //通过Map.keySet遍历 System.out.println("======根据键拿到值====="); Set keySet = map.keySet(); for (Object key : keySet) { System.out.println("键"+key+"值="+map.get(key)); } //通过For-Each迭代entries,使用Map.entrySet遍历 System.out.println("====通过映射关系得到结果===="); Set entrySet = map.entrySet(); for (Object object : entrySet) { Map.Entry entry = (Entry) object; System.out.println(entry.getKey()+ ":"+entry.getValue()); } } }
运行结果:
二.map集合的作用
1.统计频次
2.数据去重
3.快速查找
统计频次的使用:
package com.liaozhixiang.java; import java.util.HashMap; import java.util.Map; /** * * @author liao * */ public class Dome2 { public static void main(String[] args) { //定义随机字符串 String s = "ghdjhvkjeuinvmndhjvjetwqeqeashkbggsgsafqafasfasfaffjuwjal"; //做字符串切割 ,得到字符串数组 char[] arr = s.toCharArray(); System.out.println(arr); //遍历获得单个字符 Map<Character, Integer> map = new HashMap<Character, Integer>(); for (char c : arr) { System.out.println(c); Integer val = map.get(c); if(val != null) { //如果存在值key+1并且进行覆盖 map.put(c, val+1); }else { //相反则默认为1 map.put(c, 1); } } //循环遍历map集合 for (Map.Entry<Character, Integer> entry : map.entrySet()) { //打印结果 System.out.println(entry.getKey()+"出现了"+entry.getValue()+"次"); } } }
运行结果:
三.泛型
Java 泛型(generics)是 JDK 5 中引入的一个新特性, 泛型提供了编译时类型安全检测机制,该机制允许程序员在编译时检测到非法的类型。
泛型出现之前:不健壮的代码运行时会把错误暴露出来,不健壮的代码能运行但是在一些情况下会报错
泛型出现之后:将潜在的问题暴露出来
在jdk5之前没有的代码会是这样的:
package com.liaozhixiang.java; import java.util.HashSet; import java.util.Set; /** *泛型 *泛型出现之前:不健壮的代码运行时会把错误暴露出来,不健壮的代码能运行但是在一些情况下会报错 *泛型出现之后:将潜在的问题暴露出来 * 1.增加代码健壮性 * @author liao * */ public class Dome3 { public static void main(String[] args) { //以set集合为例子 Set set = new HashSet<>(); set.add(1); set.add(2); set.add(3); set.add(4); set.add(5); set.add(6); //打印偶数遍历 for (Object object : set) { if(Integer.valueOf(object.toString()) % 2 == 0) { System.out.println(object); } } } }
如果我增加的是字符串结果如下:
jdk5以后加入泛型后:
package com.liaozhixiang.java; import java.util.HashSet; import java.util.Set; /** *泛型 *泛型出现之前:不健壮的代码运行时会把错误暴露出来,不健壮的代码能运行但是在一些情况下会报错 *泛型出现之后:将潜在的问题暴露出来 * 1.增加代码健壮性 * @author liao * */ public class Dome3 { public static void main(String[] args) { //以set集合为例子 //加入泛型会提前将错误暴露 Set<Integer> set = new HashSet<>(); set.add(1); set.add(2); set.add(3); set.add(4); set.add(5); set.add(6); //添加字符串 // set.add("a"); //打印偶数遍历 for (Object object : set) { if(Integer.valueOf(object.toString()) % 2 == 0) { System.out.println(object); } //删除 // set.remove(object); } } }
结果:
总结泛型的好处
- 编译期类型安全
- 避免了强制类型转换运行时异常
- 同一个类可以操作多种类型数据,代码复用
除此之外还有泛型类,泛型方法以及更多