黑马程序员:集合框架Map

Map集合:该集合存储键值对,一对一对往里存,而且要保证键的唯一性。

  1. 1.添加元素 
  2.     put(K key,V value) 
  3.     putAll(Map<? extends K,?extends V> m) 
  4. 2.删除元素 
  5.     clear() 
  6.     remove(Object key) 
  7. 3.判断元素 
  8.     containsValue(Object value) 
  9.     containsKey(Object key) 
  10.     isEmpty() 
  11. 4.获取元素 
  12.     get(Object key) 
  13.     size() 
  14.     values() 
<span style="font-size:18px;">	1.添加元素
		put(K key,V value)
		putAll(Map<? extends K,?extends V> m)
	2.删除元素
		clear()
		remove(Object key)
	3.判断元素
		containsValue(Object value)
		containsKey(Object key)
		isEmpty()
	4.获取元素
		get(Object key)
		size()
		values()</span>


keySet():将map中所有的键存入到Set集合,应为set具备迭代器,所以可以取出所有的键,
在根据get方法,获取每一个键对应的值。

entrySet():将map集合中的映射关系存入到set集合中,而这个关系的数据类型就是map.entry


Map: 和Set很像,其实Set底层就是使用了Map集合。
|--Hashtable:底层是哈希表数据结构,不可以存入null键null值,线程同步。jdk1.0
|--HashMap:底层是哈希表数据结构,允许使用null键null值,该集合是不同步的。jdk1.2

|--TreeMap:底层是二叉树数据结构,线程不同步,可以用于给map集合中的键进行排序。


  1. import java.util.*; 
  2. class  MapDemo 
  3.     publicstatic void main(String[] args)  
  4.     { 
  5.         Map<String,String> map = new HashMap<String,String>(); 
  6.         //添加元素时,如果键值相同,那么后添加的值会覆盖原有键对应的值。 
  7.         map.put("01","zhangsan1"); 
  8.         map.put("02","zhangsan2"); 
  9.         map.put("03","zhangsan3"); 
  10.  
  11.         System.out.println(map.contansKey("022")); 
  12.         System.out.println(map.remove("02")); 
  13.         System.out.println(map.get("023"));  
  14.         //可以通过get方法的返回值来判断一个键是否存在,通过返回null来判断 
  15.          
  16.         //获取map集合中所有的值 
  17.         Collection<String> coll = map.values(); 
  18.  
  19.         //获取map中的所有键值对。 
  20.         //先获取map集合的所有键的set集合,keySet(); 
  21.         Set<String> keySet = map.keySet(); 
  22.         Iterator<String> it = keySet.iterator(); 
  23.  
  24.         while(it.hasNext()) 
  25.         { 
  26.             String key = it.next(); 
  27.             //有了键可以通过map集合的get方法获取对应的值。 
  28.             String value = map.get(key); 
  29.             System.out.println(key,value); 
  30.         } 
  31.  
  32.  
  33.  
  34.         //将Map集合中的映射关系取出,存入到set集合。 
  35.         Set<Map.Entry<String,String>> entrySet = map.entrySet(); 
  36.  
  37.         Iterator<Map.Entry<String,String>> it = entrySet.iterator(); 
  38.          
  39.         while(it.hasNext()) 
  40.         { 
  41.             Map.Entry<String,String> me = it.next(); 
  42.             String key = me.getKey(); 
  43.             String value = me.getValue(); 
  44.             System.out.println(key,value); 
  45.         } 
  46.  
  47.         /*
  48.         Map.Entry 其实Entry也是一个接口,它是Map接口中的一个内部接口
  49.         interface Map
  50.         {
  51.             public static interface Entry
  52.             {
  53.                 public abstract Object getKey();
  54.                 public abstract Object getValue();
  55.             }
  56.         }
  57.         class HashMap implements Map
  58.         {
  59.             class Hahs implements Map.Entry
  60.             {
  61.                 public Object getKey(){}
  62.                 public Object getValue(){}
  63.             }
  64.         }
  65.         */ 
  66.     } 
<span style="font-size:18px;">import java.util.*;
class  MapDemo
{
	public static void main(String[] args) 
	{
		Map<String,String> map = new HashMap<String,String>();
		//添加元素时,如果键值相同,那么后添加的值会覆盖原有键对应的值。
		map.put("01","zhangsan1");
		map.put("02","zhangsan2");
		map.put("03","zhangsan3");

		System.out.println(map.contansKey("022"));
		System.out.println(map.remove("02"));
		System.out.println(map.get("023")); 
		//可以通过get方法的返回值来判断一个键是否存在,通过返回null来判断
		
		//获取map集合中所有的值
		Collection<String> coll = map.values();

		//获取map中的所有键值对。
		//先获取map集合的所有键的set集合,keySet();
		Set<String> keySet = map.keySet();
		Iterator<String> it = keySet.iterator();

		while(it.hasNext())
		{
			String key = it.next();
			//有了键可以通过map集合的get方法获取对应的值。
			String value = map.get(key);
			System.out.println(key,value);
		}



		//将Map集合中的映射关系取出,存入到set集合。
		Set<Map.Entry<String,String>> entrySet = map.entrySet();

		Iterator<Map.Entry<String,String>> it = entrySet.iterator();
		
		while(it.hasNext())
		{
			Map.Entry<String,String> me = it.next();
			String key = me.getKey();
			String value = me.getValue();
			System.out.println(key,value);
		}

		/*
		Map.Entry 其实Entry也是一个接口,它是Map接口中的一个内部接口
		interface Map
		{
			public static interface Entry
			{
				public abstract Object getKey();
				public abstract Object getValue();
			}
		}
		class HashMap implements Map
		{
			class Hahs implements Map.Entry
			{
				public Object getKey(){}
				public Object getValue(){}
			}
		}
		*/
	}
}
</span>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值