java中Map集合的掌握

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);
	}
}
}

  

猜你喜欢

转载自blog.csdn.net/wt5264/article/details/80273903