Java集合之Map集合的使用

Map简介

映射(Map):一系列“键-值”对。从表面看,我们可以方便地查看Map的某个部分。只需创建一个集合,然后用它表示那一部分即可。这样一来,Map就可以返回自己键的一个Set、一个包含自己值的List或者包含自己“键-值”对的一个List。(简单的列出了Think in Java中的几句话)

Map的简单使用以及三种遍历方式
// 创建集合对象
		Map<String, String> map = new HashMap<String, String>();
		// 创建并添加元素
		map.put("1", "姚明");
		map.put("2", "奥胖");
		map.put("3", "火花");

		// 获取key的集合
		Set<String> set = map.keySet();
		// 遍历Set集合
		Iterator<String> it = set.iterator();
		while (it.hasNext()) {
			String s = it.next();
			System.out.println(s);
           (这里就是map的key  1、2、3)
		}
		// 获取value的集合
		Collection<String> c = map.values();
		// 遍历Collection集合
		it = c.iterator();
		while (it.hasNext()) {
			String s = it.next();
			System.out.println(s);
		   (这里就是map的value  姚明、奥胖、火花)
		}

我们使用集合存储数据就是为了读取数据接下来我们看看Map集合的遍历

// 遍历----先拿到Map集合的key然后在根据key取对应的value值
		Set<String> set = map.keySet();
		for (String key : set) {
			String value = map.get(key);
			System.out.println(key + "-----"+value);
		}
		
// 遍历----先拿到Map集合的value值的集合然后遍历这个集合
   Collection values = map.values();
    Iterator iterator = values.iterator();
    while (iterator.hasNext()){
        System.out.println("value " +"-----"+ iterator.next());
    }
    
// 遍历----先拿到Map集合的映射对象的集合然后在从中取出数据
// Map集合有一个Entry集合存放其key和value的对应关系
Set<Map.Entry<String, String>> set = map.entrySet();
		for (Entry<String, String> entry: set) {
			String key = entry.getKey();//获取map的key
			String value = entry.getValue();//获取map的value
			System.out.println(key + "-----" + value);
		}

Map集合的子类实现与对比
|--Map(双列 底层结构是针对键有效,跟值无关,Map有三个子类分别是)
			|--HashMap
				底层数据结构是哈希表。
				线程不安全,效率高。
				允许null键和值。
			|--Hashtable
				底层数据结构是哈希表。
				线程安全,效率低。
				不允许null键和值。
			|--TreeMap
				底层数据结构是二叉树。
				线程不安全,效率高。

什么时候使用map什么时候使用collection

是否键值对?
		是:Map
			是否对键排序?
				是:TreeMap
				否:HashMap
		否:Collection

有时候为了保证map集合数据的唯一性我们必须重写equals() 和 hashCode()方法,这两个方法应该是必须掌握的。可以看一下这个写的非常好。
equals() 和 hashCode()方法的重写

thanks
https://java.quanke.name/8.7%20%E6%96%B0%E9%9B%86%E5%90%88.html
http://blog.csdn.net/u011240877/article/details/52929523

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值