JAVA【Map集合】详解


Map集合概述和使用

  • Map集合是一种双列集合,每个元素包含两个数据。
  • Map集合的每个元素的格式: key=value(键值对元素)。
  • Map集合也被称为“键值对集合”。

在这里插入图片描述


Map集合体系

在这里插入图片描述

详细信息

在这里插入图片描述


JDK7 HashMap如何实现

Java7 HashMap采用的是冲突链表方式。

在这里插入图片描述


JDK8 HashMap如何实现

Java7 HashMap查找的时候,根据 hash 值能够快速定位到数组的具体下标,之后需要顺着链表一个个比较下去才能找到目标,时间复杂度取决于链表的长度,为 O(n)
为了降低这部分的开销,在 Java8 中,当链表中的元素达到了 8 个时,会将链表转换为红黑树,在这些位置进行查找的时候可以降低时间复杂度为 O(logN)

在这里插入图片描述


Map集合体系特点

在这里插入图片描述

Map集合实现类特点

在这里插入图片描述


Map API

在这里插入图片描述


HashSet是如何实现的

HashSet是对HashMap的简单包装,对HashSet的函数调用都会转换成合适的HashMap方法

//HashSet是对HashMap的简单包装
public class HashSet<E>
{
	......
	private transient HashMap<E,Object> map;//HashSet里面有一个HashMap
    // Dummy value to associate with an Object in the backing Map
    private static final Object PRESENT = new Object();
    public HashSet() {
        map = new HashMap<>();
    }
    ......
    public boolean add(E e) {//简单的方法转换
        return map.put(e, PRESENT)==null;
    }
    ......
}

总结

在这里插入图片描述

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,Map是一种键值对的数据结构。它允许我们根据键来存储和访问值。而对Map进行排序就是按照键或值的顺序对Map进行排序。 对Map进行排序有多种方式。以下是两种常见的方法: 1. 使用TreeMap TreeMap是一种基于红黑树数据结构实现的排序Map。在TreeMap中,元素是按照键的自然顺序或者按照Comparator进行排序的。这意味着,只需要将元素插入到TreeMap中,就可以获得排序的Map。 示例代码: //按照键的自然顺序进行排序 Map<String, Integer> map = new TreeMap<String, Integer>(); map.put("b", 2); map.put("c", 3); map.put("a", 1); //按照值的顺序进行排序 Map<String, Integer> sortedMap = new TreeMap<String, Integer>(new Comparator<String>() { public int compare(String o1, String o2) { return map.get(o1).compareTo(map.get(o2)); //按值比较 } }); sortedMap.putAll(map); 2. 使用Collections.sort方法 Collections.sort方法可以对List进行排序。因此,将Map转换为List,然后对List进行排序,最后将排序后的List转换回Map,就可以对Map进行排序。 示例代码: //对Map按键排序 List<Map.Entry<String, Integer>> list = new ArrayList<Map.Entry<String, Integer>>(map.entrySet()); Collections.sort(list, new Comparator<Map.Entry<String, Integer>>() { public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) { return o1.getKey().compareTo(o2.getKey()); //按键比较 } }); Map<String, Integer> sortedMap = new LinkedHashMap<String, Integer>(); //保持插入顺序 for (Map.Entry<String, Integer> entry : list) { sortedMap.put(entry.getKey(), entry.getValue()); } //对Map按值排序 List<Map.Entry<String, Integer>> list = new ArrayList<Map.Entry<String, Integer>>(map.entrySet()); Collections.sort(list, new Comparator<Map.Entry<String, Integer>>() { public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) { return o1.getValue().compareTo(o2.getValue()); //按值比较 } }); Map<String, Integer> sortedMap = new LinkedHashMap<String, Integer>(); //保持插入顺序 for (Map.Entry<String, Integer> entry : list) { sortedMap.put(entry.getKey(), entry.getValue()); } 可以看出,使用TreeMap比较简单,但是对于按值排序需要使用自定义Comparator。而使用Collections.sort方法需要进行List和Map之间的转换,但是比较灵活,可以自定义排序规则。 总之,对于Map的排序,需要根据实际需求选择适合的方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值