JAVA集合学习之Map篇
1.Map 接口和常用方法
1.1Map 接口实现类的特点

image-20220607164146160
1.Map用于保存具有映射关系的数据:Key-Value
2.Map中的key和value可以是任何引用类型的数据,会封装到HashMap$Node对象中
3.Map中的key不允许重复,原因和HashSet一样,Set篇文章分析过源码
4.Map中的value可以重复
5.Map的key可以为null,value也可以为null,注意key为null,只能为一个,value为null,可以多个
6.常用String类作为Map的key
7.key和value之间存在单向一对一关系,即通过指定的key总能找到对应的value
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
| package com.hspedu.map_;
import java.util.HashMap; import java.util.Map;
@SuppressWarnings({"all"}) public class Map_ { public static void main(String[] args) { Map map = new HashMap(); map.put("no1", "韩顺平"); map.put("no2", "张无忌"); map.put("no1", "张三丰"); map.put("no3", "张三丰"); map.put(null, null); map.put(null, "abc"); map.put("no4", null); map.put("no5", null); map.put(1, "赵敏"); map.put(new Object(), "金毛狮王"); System.out.println(map.get("no2"));
System.out.println("map=" + map);
} }
|
8.Map存放数据的key-value示意图,一对k-v是放在一个HashMap$Node中的,因为Node实现了Entry接口,有些书上也说一对k-v就是一个Entry(如图)

image-20220607163543659
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
| package com.hspedu.map_;
import java.util.Collection; import java.util.HashMap; import java.util.Map; import java.util.Set;
@SuppressWarnings({"all"}) public class MapSource_ { public static void main(String[] args) { Map map = new HashMap(); map.put("no1", "韩顺平"); map.put("no2", "张无忌"); map.put(new Car(), new Person());
Set set = map.entrySet(); System.out.println(set.getClass()); for (Object obj : set) {
Map.Entry entry = (Map.Entry) obj; System.out.println(entry.getKey() + "-" + entry.getValue() ); }
Set set1 = map.keySet(); System.out.println(set1.getClass()); Collection values = map.values(); System.out.println(values.getClass()); } }
class Car {
}
class Person{
}
|
1.2Map 接口常用方法
remove:根据键删除映射关系
get:根据键获取值
size:获取元素个数
isEmpty:判断个数是否为0
clear:清除k-v
containsKey:查找键是否存在
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
| package com.hspedu.map_;
import java.util.HashMap; import java.util.Map;
@SuppressWarnings({"all"}) public class MapMethod { public static void main(String[] args) {
Map map = new HashMap(); map.put("邓超", new Book("", 100)); map.put("邓超", "孙俪"); map.put("王宝强", "马蓉"); map.put("宋喆", "马蓉"); map.put("刘令博", null); map.put(null, "刘亦菲"); map.put("鹿晗", "关晓彤"); map.put("hsp", "hsp的老婆");
System.out.println("map=" + map);
map.remove(null); System.out.println("map=" + map);
Object val = map.get("鹿晗"); System.out.println("val=" + val);
System.out.println("k-v=" + map.size());
System.out.println(map.isEmpty());
System.out.println("map=" + map);
System.out.println("结果=" + map.containsKey("hsp"));
} }
class Book { private String name; private int num;
public Book(String name, int num) { this.name = name; this.num = num; } }
|
2.Map接口的遍历方式
1 2 3 4 5 6 7 8
| Map map = new HashMap();
Set keyset = map.keySet();
Collection values = map.values();
Set entrySet = map.entrySet();
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
| package com.hspedu.map_;
import java.util.*;
@SuppressWarnings({"all"}) public class MapFor { public static void main(String[] args) {
Map map = new HashMap(); map.put("邓超", "孙俪"); map.put("王宝强", "马蓉"); map.put("宋喆", "马蓉"); map.put("刘令博", null); map.put(null, "刘亦菲"); map.put("鹿晗", "关晓彤");
Set keyset = map.keySet(); System.out.println("-----第一种方式-------"); for (Object key : keyset) { System.out.println(key + "-" + map.get(key)); } System.out.println("----第二种方式--------"); Iterator iterator = keyset.iterator(); while (iterator.hasNext()) { Object key = iterator.next(); System.out.println(key + "-" + map.get(key)); }
Collection values = map.values(); System.out.println("---取出所有的value 增强for----"); for (Object value : values) { System.out.println(value); } System.out.println("---取出所有的value 迭代器----"); Iterator iterator2 = values.iterator(); while (iterator2.hasNext()) { Object value = iterator2.next(); System.out.println(value);
}
Set entrySet = map.entrySet(); System.out.println("----使用EntrySet 的 for增强(第3种)----"); for (Object entry : entrySet) { Map.Entry m = (Map.Entry) entry; System.out.println(m.getKey() + "-" + m.getValue()); } System.out.println("----使用EntrySet 的 迭代器(第4种)----"); Iterator iterator3 = entrySet.iterator(); while (iterator3.hasNext()) { Object entry = iterator3.next(); Map.Entry m = (Map.Entry) entry; System.out.println(m.getKey() + "-" + m.getValue()); }
} }
|
3.HashMap小结
1.Map接口的常用实现类:HashMap、Hashtable、Properties
2.HashMap是Map接口使用频率最高的实现类
3.HashMap是以key-val对的方式来存储数据(HashMap$Node类型)
4.key不能重复,但是值可以重复,允许使用null键和null值
5.如果添加相同的key,则会覆盖原来的key-val,等同于修改。(key不会替换,val会替换)
6.于HashSet一样,不能保证映射的顺序,因为底层是以hash表的方式来存储的。
(jdk8的hashMap底层 数组+链表+红黑树)
7.HashMap没有实现同步,因此是线程不安全的,方法没有做同步互斥的操作,没有synchronized