集合框架学习笔记(下)

第一章Map集合

1.1概述

现实生活中,我们常会看到这样的一个集合:IP地址与主机名,身份证号与个人,系统用户名与系统对象等。

这种一一对应的关系,就叫做映射。JAVA提供了专门的集合类用来存放这种有映射关系的对象,即java.util.Map接口。

Map集合与Collection集合存储数据的形式不同:

  • Collection中的集合,元素是孤立存在的(理解为单身),向集合中存储元素采用一个个元素方式存储
  • Map中的集合,元素是成对存在的(理解为夫妻)。每个元素由key和value组成,通过key可以找到相应的值
  • Collection中的集合称为单列集合,Map中的集合称为双列集合
  • 需要注意的是,Map中的集合不能包含重复的key,value可以重复;每个键只能对应一个值

1.2 Map常用的子类

  • HashMap<K,V>:存储数据采用哈希表结构,元素的存取顺序不能保证一致。由于要保证键的唯一,不重复,需要重写键的hashCode()方法和equals()方法。
  • LinkedHashMap<K,V>:HashMap下有个子类LinkedHashMap,存储数据采用哈希表结构+链表结构。通过链表结构可以保证元素的存取顺序一致;通过哈希表结构可以保证键的唯一,不重复,需要重写键的hashCode()方法和equals()方法。

1.3 Map接口中的常用方法

Map接口中定义了很多方法,常用如下:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JibBjRxo-1588355161680)(C:\Users\LENOVO\AppData\Roaming\Typora\typora-user-images\image-20200501223654095.png)]

put方法:

private static void show1() {
    //创建Map集合,使用多态
    Map<String,String> map = new HashMap<>();

    String v1 = map.put("李晨", "范冰冰1");
    System.out.println("v1"+v1);//没有重复的key,返回null

    String v2 = map.put("李晨", "范冰冰2");
    System.out.println("v2"+v2);//有重复的key,用新的value替换掉久的,返回被替换掉的值

    System.out.println(map);//{李晨=范冰冰2}

    map.put("丁国梁","23");
    map.put("王雪菲","22");
    map.put("黄佳玲","19");
    map.put("单辉","23");
    System.out.println(map);//key不可以重复,value可以重复
}

remove方法:

private static void show2() {
    //创建Map集合
    Map<String,Integer> map = new HashMap<>();
    map.put("丁国梁",23);
    map.put("王雪菲",22);
    map.put("黄佳玲",19);
    map.put("单辉",23);
    System.out.println(map);//{王雪菲=22, 丁国梁=23, 黄佳玲=19, 单辉=23}
    Integer v1 = map.remove("单辉");
    System.out.println(map);//{王雪菲=22, 丁国梁=23, 黄佳玲=19}
    System.out.println(v1);//  返回23,是被删除的key对应的值
    
    Integer v2 = map.remove("熊金娜");
    System.out.println(map);//{王雪菲=22, 丁国梁=23, 黄佳玲=19}
    System.out.println(v1);//  返回null,当删除不存在的key时返回null

get方法:

通过key来获取对应的值,如果key不存在返回null

1.4 Map集合遍历键找值方式

分析步骤:

1. 获取Map所有键,由于键是唯一的,所以返回一个Set集合存储所有的键,使用keyset()方法

2. 遍历键的Set集合,得到每一个键
3. 根据键,获取键所对应的值。 方法:get(K key)

keyset()方法:

//遍历Map集合第一种方式:键找值方式
private static void show3() {
    //创建Map集合
    Map<String,Integer> map = new HashMap<>();
    map.put("丁国梁",23);
    map.put("王雪菲",22);
    map.put("黄佳玲",19);
    map.put("单辉",23);
    Set<String> s1 = map.keySet();//
    System.out.println(s1);
    for (String s : s1) {
           Integer v2 = map.get(s);
           System.out.println(s1 + "=" + v2);
       }
}

1.5 Entry键值对对象

在Map中一一对应的key和value被称为Entry(项)。Entry将键值对的对应关系封装成对象。即键值对对象,这样我们在遍历Map集合时,就可以从每一个键值对(Entry)对象中获取对应的键与对应的值。

​ 既然Entry表示了一对键和值,那么也同样提供了获取对应键和对应值的方法:

  • public K getKey():获取Entry对象中的键
  • public K getValue():获取Entry对象中的值

在Map集合中也提供了获取所有Entry对象的方法:

  • public Set<Map.Entry<K,V>>entrySet():获取到Map集合中所有的键值对对象的集合(set集合)
/**
 * Map集合遍历的第二种方式:使用Entry对象遍历
 * Map集合中的方法:
 * public Set<Map.Entry<K,V>>entrySet():获取到Map集合中所有的键值对对象的集合(set集合)
 * 实现步骤:
 * 1.使用entrySet取Entry,存到set集合中
 * 2.遍历这个set集合,获取每一个Entry对象
 * 3.使用Entry对象中的方法getKey()和getValue获取键与值
 */
public class d2MapDemo2 {
    public static void main(String[] args) {
        Map<String, Integer> map = new HashMap<>();
        map.put("丁国梁", 23);
        map.put("王雪菲", 22);
        map.put("黄佳玲", 19);
        map.put("单辉", 23);
        Set<Map.Entry<String, Integer>> set = map.entrySet();
        for (Map.Entry<String, Integer> stringIntegerEntry : set) {
            String key = stringIntegerEntry.getKey();
            Integer value = stringIntegerEntry.getValue();
            System.out.println(key + "=" + value);
        }
    }
}

1.6 HashMap存储自定义类型键值

  • HashMap的key参数使用自定义类时,需要在自定义类中重写hashcode和equals方法,来保证key值的唯一性

1.7 LinkedHashMap

  • 和之前学过的LinkedHashSet一样,特点使用哈希表查询速度快,且加上了链表,保证了元素的一致性
  • 在存储自定义类型键值时也需要重写hashcode和equals方法

1.8 Hashtable集合(了解即可)

在这里插入图片描述

第二章 补充知识点

2.1 JDK9对集合添加的优化

JDK9新特性:
List接口,Set接口,Map接口:增加了一个静态方法of,可以一次性添加多个元素
使用前提:当集合中存储的元素的个数已经确定了,不再改变时使用
注意:
1.of方法只适用于List接口,Set接口,Map接口。不适用于接口的实现类
2.of方法的返回值是一个不能改变的集合,集合不能在使用add和put方法添加元素,会抛出异常
3.Set接口和Map接口在调用of方法的时候,不能有重复的元素,否则也会抛出异常

2.2 Debug追踪

使用IDEA的断点调试功能,查看程序的运行过程

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值