[问题引入]
需求:有很多学生,学生有姓名,有学号,根据学生的学号查找学生?
之前学习的集合,可以将姓名,学号作为学生类的中两个成员变量,创建集合的时候存储这个类型,可以的
关键只知道学生学号,通过学号找姓名
Key Value
学号1 姓名1
学号2 姓名2
学号3 姓名3
Java针对这种技术----->Map集合 ,键值的映射关系的一种集合(接口)
一.Map集合
将键映射到值的对象。一个映射不能包含重复的键;每个键最多只能映射到一个值。
Map<K,V> ,在Map集合中,只针对键有效,跟值无关
Map接口的子实现类:HashMap和TreeMap
[面试题]Map集合和Collection的区别?
Map集合:是一种键和值的映射关系(双列集合) 当作为:夫妻对
Collection集合:单列集合,只能存储一种类型的元素,当作为:光棍
间接关系:HashSet依赖于Map接口的子实现类HashMap的
TreeSet依赖于Map接口的子实现类TreeMap的
1.Map接口的功能:
添加功能
V put(K key,V value) :将指定的值和键关联起来
如果当前的这个键是一次存储,则返回值null
如果不是第一次存储,返回值是第一次对应的值,当前的值就把之前的键对应的值替换掉!
获取功能
Set<Map.Entry<K,V>> entrySet() :和Map集合的遍历有关系(键值对对象)
Set<K> keySet():获取映射关系中所有的键的集合
int size()返回此映射中的键-值映射关系数
删除功能
void clear():删除所有映射关系
V remove(Object key)如果存在一个键的映射关系,则将其从此映射中移除
判断功能:
boolean containsKey(Object key)如果此映射包含指定键的映射关系,则返回 true
boolean containsValue(Object value):映射关系中是否包含指定的值
boolean isEmpty():判断映射关系是否为空
2.Map集合的遍历
(1)通过keySet()获取所有的键的集合 :这种方式使用最多
Set<K> keySet():获取映射关系中所有的键的集合
V get(Object key):通过键找值
思路:
* 1)获取所有的键的集合
* 2)通过键找它对应的值
* 3)遍历即可
public static void main(String[] args) {
//创建Map集合
Map<String,String> map = new HashMap<String,String>() ;
//添加元素
map.put("杨过", "小龙女") ;
map.put("郭靖", "黄蓉") ;
map.put("陈旋风", "梅超风") ;
map.put("高圆圆", "赵又廷") ;
//遍历
//先获取所有的键的集合
Set<String> set = map.keySet() ;
//遍历素有的键,获取每一个键
for(String key :set) {
//通过键找值
String value = map.get(key) ;
System.out.println(key+"="+value);
}
}
(2) 通过获取键值对对象entrySet() ;
Set<Map.Entry<K,V>> entrySet() :和Map集合的遍历有关系(键值对对象)
思路:
* 1)获取所有的键值对象entrySet()
* 2) K getKey() 和 v getValue(),获取键值对对象中的每个键和每个值
* 3)遍历
public static void main(String[] args) {
// 创建Map集合对象
Map<String, String> map = new HashMap<String, String>();
// 添加元素
map.put("杨过", "小龙女");
map.put("郭靖", "黄蓉");
map.put("陈旋风", "梅超风");
map.put("高圆圆", "赵又廷");
//获取所有的键值对对象
Set<Map.Entry<String, String>> entrySet = map.entrySet() ;
//增强for
for(Map.Entry<String, String> entry :entrySet) {
//获取到每一个键值对对象
//通过键值对对象找键和值
String key = entry.getKey() ;
String value = entry.getValue() ;
System.out.println(key+"="+value);
}
}