Map集合的引入:

需求:有很多学生,学生有姓名,有学号,根据学生的学号查找学生?

  之前学习的集合,可以将姓名,学号作为学生类的中两个成员变量,创建集合的时候存储这个类型,可以的


 


  关键只知道学生学号,通过学号找姓名


  

Key Value


  



  学号1

姓名1


  学号2

姓名2


  学号3

姓名3


  学号1(重复的键)

姓名4


  


  Java针对这种技术----->Map集合 ,键值的映射关系的一种集合(接口)


  将键映射到值的对象。一个映射不能包含重复的键;每个键最多只能映射到一个值。 


  Map<K,V>

,在Map集合中,只针对键有效,跟值无关 Map接口的子实现类:HashMap和TreeMap


  


  面试题:


  

Map集合和Collection的区别?


  



  

Map集合:是一种键和值的映射关系(双列集合) 当作为:夫妻对


  

Collection集合:单列集合,只能存储一种类型的元素,当作为:光棍


  

间接关系:HashSet依赖于Map接口的子实现类HashMap的


 

   TreeSet依赖于Map接口的子实现类TreeMap的


 


  


  Map接口的功能:


  

V put(K key,V value) :添加功能:将指定的值和键关联起来


  

如果当前的这个键是一次存储,则返回值null


  

如果不是第一次存储,返回值是第一次对应的值,当前的值就把之前的键对应的值替换掉!


 



 

获取功能


  

Set<Map.Entry<K,V>> entrySet() :和Map集合的遍历有关系(键值对对象)


  

Set<K> keySet():获取映射关系中所有的键的集合


  

int size()返回此映射中的键-值映射关系数


  

删除功能


  

void clear():删除所有映射关系


   

Vremove(Object key)如果存在一个键的映射关系,则将其从此映射中移除


   


   

判断功能:


  

boolean containsKey(Object key)如果此映射包含指定键的映射关系,则返回 true


  

boolean containsValue(Object value):映射关系中是否包含指定的值


boolean isEmpty():判断映射关系是否为空

举例:

* @author 田伟
 *
 */
public class MapDemo {
	public static void main(String[] args) {
		Map<String,String> map=new HashMap<String,String>();
	    System.out.println(map);
	   //添加功能
	    map.put("牛头", "马面");
	    map.put("快快", "乐乐");
	    map.put("叮叮", "当当");
	    System.out.println(map);
//	    map.clear();
	    System.out.println(map);
	    System.out.println(map.remove("牛头"));
        System.out.println(map);
        System.out.println(map.containsKey("快快"));
        System.out.println(map.containsValue("当当"));	
	    System.out.println(map);
	}
}

这种遍历方式实际开发中经常用的...


  Set<K> keySet():获取映射关系中所有的键的集合


  V get(Object key):通过键找值


  转换法:


  

1)将所有的丈夫集中起来


 

2)让丈夫它对应的妻子


  

3)将他们遍历出来


 思路:


  

1)获取所有的键的集合


 

2)通过键找它对应的值


3)遍历即可

举例:

* @author 田伟
 *
 */
public class MapDemo2 {
public static void main(String[] args) {
	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) {
		System.out.println(key);
	}
	for(String key:set) {
		String value=map.get(key);
		System.out.println(value);
	}
}
}

Map集合的另一种方式的遍历 Set<Map.Entry<K,V>> entrySet() :和Map集合的遍历有关系(键值对对象)


 转发法:  1)获取所有的结婚证 


                2)通过结婚证分别找对应的丈夫和妻子 


                3)遍历输出


  思路: 1)获取所有的键值对象entrySet()


          2) K getKey() 和 v getValue(),获取键值对对象中的每个键和每个值


          3)遍历

举例:

* @author 田伟
 *
 */
public class MapDemo3 {
public static void main(String[] args) {
	Map<String,String> map=new HashMap<String,String>();
	map.put("杨过", "小龙女");
	map.put("郭靖", "黄蓉");
	map.put("陈旋风", "梅超风");
	map.put("高圆圆", "赵又廷");
	Set<Map.Entry<String,String>> en=map.entrySet();
	for(Map.Entry<String, String> entry:en) {
		String value=entry.getValue();
		String key=entry.getKey();
		System.out.println(key+"="+value);
	}
}
}