Map集合的使用-Java

简介: Map集合的使用-Java

Map集合是键值对集合,集合的每个元素的格式:key=value(键值对元素)。

Map集合的完整格式:{key1=value1 , key2=value2 , key3=value3 , ...}

特点:Map集合的键是无序、不重复、无索引的,键值对都可以为null

主要的有:HashMap , LinkedHashMap , TreeMap

HashMap:元素按照键是无序,不重复,无索引,值不做要求。

LinkedHashMap:元素按照键是有序,不重复,无索引,值不做要求。

TreeMap:元素按照建是排序,不重复,无索引的,值不做要求。

  • 添加元素  put()
  • 删除  remove() clear()
  • 是否包含键或值  containsKey() containsValue()
  • 是否空  isEmpty()
  • ...
Map<String ,Integer> maps=new HashMap<>();
        maps.put("tea",18);
        maps.put("coffee",16);
        maps.put("toc",8);
        System.out.println(maps);
        //根据键:找值、删除、是否包含
        System.out.println(maps.get("tea"));
        System.out.println(maps.get("tec"));
        System.out.println(maps.remove("toc"));
        System.out.println(maps.containsKey("tea"));
        //是否有这个值
        System.out.println(maps.containsValue(16));
        //获取全部键的集合      键也是不重复的,所以用set
        Set<String> keys=maps.keySet();
        System.out.println(keys);
        //获取全部值的集合      值可以重复
        Collection<Integer> val=maps.values();
        System.out.println(val);
  • 遍历一个Map集合
  • 方式一:键找值的方式遍历:先获取Map集合全部的键,再根据遍历键找值。
  • 方式二:键值对的方式遍历,把“键值对“看成一个整体。
  • 方式三:JDK 1.8开始的:Lambda表达式。
System.out.println("- 1. 循环 键找值 ---------------------------------------");
        for (String tag:maps.keySet()) {
            System.out.println(tag+"="+maps.get(tag));
        }
        System.out.println("- 2. Map集合转Set集合 -----------------------------");
        Set<Map.Entry<String,Integer>> entries=maps.entrySet();
        System.out.println(entries);
        for(Map.Entry<String,Integer> entry:entries){
            String key=entry.getKey();
            Integer value=entry.getValue();
            System.out.println(key + "=" + value);
        }
        System.out.println("- 3. Lambda forEach 其实内部有个Entry的for循环 返回键和值在" +
                "accept里面输出 ----------------");
        maps.forEach(new BiConsumer<String, Integer>() {
            @Override
            public void accept(String s, Integer integer) {
                System.out.println(s+"="+integer);
            }
        });
  1. HashMap的特点

由键决定:无序、不重复、无索引。

HashMap底层是哈希表结构,依赖hashCode方法和equals方法保证键的唯一。

键要存储的是自定义对象,类似HashSet也是需要重写hashCode和equals方法。

  1. LinkedHashMap集合

由键决定:有序、不重复、无索引。保证存储和取出的元素顺序一致

每个键值对元素额外的多了一个双链表记录存储的顺序。

  1. TreeMap集合

由键决定:不重复、无索引、可排序

可排序:按照键数据的大小默认升序排序。

TreeMap集合自定义排序规则:

  • 类实现Comparable接口,重写比较规则。
  • 集合自定义Comparator比较器对象,重写比较规则。
相关文章
|
11天前
|
Java
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式。本文介绍了 Streams 的基本概念和使用方法,包括创建 Streams、中间操作和终端操作,并通过多个案例详细解析了过滤、映射、归并、排序、分组和并行处理等操作,帮助读者更好地理解和掌握这一重要特性。
21 2
|
11天前
|
安全 Java
Java多线程集合类
本文介绍了Java中线程安全的问题及解决方案。通过示例代码展示了使用`CopyOnWriteArrayList`、`CopyOnWriteArraySet`和`ConcurrentHashMap`来解决多线程环境下集合操作的线程安全问题。这些类通过不同的机制确保了线程安全,提高了并发性能。
|
16天前
|
存储 Java
判断一个元素是否在 Java 中的 Set 集合中
【10月更文挑战第30天】使用`contains()`方法可以方便快捷地判断一个元素是否在Java中的`Set`集合中,但对于自定义对象,需要注意重写`equals()`方法以确保正确的判断结果,同时根据具体的性能需求选择合适的`Set`实现类。
|
16天前
|
存储 Java 开发者
在 Java 中,如何遍历一个 Set 集合?
【10月更文挑战第30天】开发者可以根据具体的需求和代码风格选择合适的遍历方式。增强for循环简洁直观,适用于大多数简单的遍历场景;迭代器则更加灵活,可在遍历过程中进行更多复杂的操作;而Lambda表达式和`forEach`方法则提供了一种更简洁的函数式编程风格的遍历方式。
|
16天前
|
Java 开发者
|
20天前
|
存储 Java API
Java交换map的key和value值
通过本文介绍的几种方法,可以在Java中实现Map键值对的交换。每种方法都有其优缺点,具体选择哪种方法应根据实际需求和场景决定。对于简单的键值对交换,可以使用简单遍历法或Java 8的Stream API;对于需要处理值不唯一的情况,可以使用集合存储或Guava的Multimap。希望本文对您理解和实现Java中的Map键值对交换有所帮助。
27 1
|
28天前
|
安全 Java 程序员
深入Java集合框架:解密List的Fail-Fast与Fail-Safe机制
本文介绍了 Java 中 List 的遍历和删除操作,重点讨论了快速失败(fail-fast)和安全失败(fail-safe)机制。通过普通 for 循环、迭代器和 foreach 循环的对比,详细解释了各种方法的优缺点及适用场景,特别是在多线程环境下的表现。最后推荐了适合高并发场景的 fail-safe 容器,如 CopyOnWriteArrayList 和 ConcurrentHashMap。
55 5
|
28天前
|
存储 缓存 安全
在Java的Map家族中,HashMap和TreeMap各具特色
【10月更文挑战第19天】在Java的Map家族中,HashMap和TreeMap各具特色。HashMap基于哈希表实现,提供O(1)时间复杂度的高效操作,适合性能要求高的场景;TreeMap基于红黑树,提供O(log n)时间复杂度的有序操作,适合需要排序和范围查询的场景。两者在不同需求下各有优势,选择时需根据具体应用场景权衡。
30 2
|
15天前
|
存储 Java 开发者
Java中的集合框架深入解析
【10月更文挑战第32天】本文旨在为读者揭开Java集合框架的神秘面纱,通过深入浅出的方式介绍其内部结构与运作机制。我们将从集合框架的设计哲学出发,探讨其如何影响我们的编程实践,并配以代码示例,展示如何在真实场景中应用这些知识。无论你是Java新手还是资深开发者,这篇文章都将为你提供新的视角和实用技巧。
12 0
|
20天前
|
Java API Apache
java集合的组内平均值怎么计算
通过本文的介绍,我们了解了在Java中计算集合的组内平均值的几种方法。每种方法都有其优缺点,具体选择哪种方法应根据实际需求和场景决定。无论是使用传统的循环方法,还是利用Java 8的Stream API,亦或是使用第三方库(如Apache Commons Collections和Guava),都可以有效地计算集合的组内平均值。希望本文对您理解和实现Java中的集合平均值计算有所帮助。
24 0
下一篇
无影云桌面