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比较器对象,重写比较规则。
相关文章
|
2天前
|
存储 安全 Java
Java一分钟之-Map接口与HashMap详解
【5月更文挑战第10天】Java集合框架中的`Map`接口用于存储唯一键值对,而`HashMap`是其快速实现,基于哈希表支持高效查找、添加和删除。本文介绍了`Map`的核心方法,如`put`、`get`和`remove`,以及`HashMap`的特性:快速访问、无序和非线程安全。讨论了键的唯一性、`equals()`和`hashCode()`的正确实现以及线程安全问题。通过示例展示了基本操作和自定义键的使用,强调理解这些概念对编写健壮代码的重要性。
6 0
|
2天前
|
存储 安全 Java
Java一分钟之-集合框架进阶:Set接口与HashSet
【5月更文挑战第10天】本文介绍了Java集合框架中的`Set`接口和`HashSet`类。`Set`接口继承自`Collection`,特征是不允许重复元素,顺序不确定。`HashSet`是`Set`的实现,基于哈希表,提供快速添加、删除和查找操作,但无序且非线程安全。文章讨论了`HashSet`的特性、常见问题(如元素比较规则、非唯一性和线程安全性)以及如何避免这些问题,并提供了代码示例展示基本操作和自定义对象的使用。理解这些概念和注意事项能提升代码效率和可维护性。
9 0
|
2天前
|
存储 安全 算法
Java一分钟之-Java集合框架入门:List接口与ArrayList
【5月更文挑战第10天】本文介绍了Java集合框架中的`List`接口和`ArrayList`实现类。`List`是有序集合,支持元素重复并能按索引访问。核心方法包括添加、删除、获取和设置元素。`ArrayList`基于动态数组,提供高效随机访问和自动扩容,但非线程安全。文章讨论了三个常见问题:索引越界、遍历时修改集合和并发修改,并给出避免策略。通过示例代码展示了基本操作和安全遍历删除。理解并正确使用`List`和`ArrayList`能提升程序效率和稳定性。
7 0
|
2天前
|
存储 Java
【JAVA基础篇教学】第十篇:Java中Map详解说明
【JAVA基础篇教学】第十篇:Java中Map详解说明
|
3天前
|
存储 安全 Java
Java容器类List、ArrayList、Vector及map、HashTable、HashMap
Java容器类List、ArrayList、Vector及map、HashTable、HashMap
|
4天前
|
存储 安全 算法
掌握Java并发编程:Lock、Condition与并发集合
掌握Java并发编程:Lock、Condition与并发集合
11 0
|
4天前
|
存储 安全 Java
深入理解Java集合框架
深入理解Java集合框架
9 0
|
9天前
|
存储 安全 Java
Java集合的分类有哪些?
Java中的集合就像一个容器,专门用来存储Java对象,这些对象可以是任意的数据类型,并且长度可变。这些集合类都位于java.util包中,在使用时一定要注意导包的问题,否则会出现异常。
36 10
|
13天前
|
安全 Java
循环的时候去删除集合中的元素 java.util.ConcurrentModificationException
循环的时候去删除集合中的元素 java.util.ConcurrentModificationException
|
13天前
|
Java
java Map删除值为null的元素
java Map删除值为null的元素