Map学习一之基本操作方法putgetremovecontainsKey

35次阅读

共计 2349 个字符,预计需要花费 6 分钟才能阅读完成。

package com.itheima.demo01.Map;

import java.util.HashMap;
import java.util.Map;

/*

java.util.Map<k,v> 集合
Map 集合的特点:
    1.Map 集合是一个双列集合, 一个元素包含两个值 (一个 key, 一个 value)
    2.Map 集合中的元素,key 和 value 的数据类型可以相同, 也可以不同
    3.Map 集合中的元素,key 是不允许重复的,value 是可以重复的
    4.Map 集合中的元素,key 和 value 是一一对应
java.util.HashMap<k,v> 集合 implements Map<k,v> 接口
HashMap 集合的特点:
    1.HashMap 集合底层是哈希表: 查询的速度特别的快
        JDK1.8 之前: 数组 + 单向链表
        JDK1.8 之后: 数组 + 单向链表 | 红黑树 (链表的长度超过 8): 提高查询的速度
    2.hashMap 集合是一个无序的集合, 存储元素和取出元素的顺序有可能不一致 

java.util.LinkedHashMap<k,v> 集合 extends HashMap<k,v> 集合
LinkedHashMap 的特点:

    1.LinkedHashMap 集合底层是哈希表 + 链表 (保证迭代的顺序)
    2.LinkedHashMap 集合是一个有序的集合, 存储元素和取出元素的顺序是一致的 

*/
public class Demo01Map {

public static void main(String[] args) {show04();
}

/*
    boolean containsKey(Object key) 判断集合中是否包含指定的键。包含返回 true, 不包含返回 false
 */
private static void show04() {
    // 创建 Map 集合对象
    Map<String,Integer> map = new HashMap<>();
    map.put("赵丽颖",168);
    map.put("杨颖",165);
    map.put("林志玲",178);

    boolean b1 = map.containsKey("赵丽颖");
    System.out.println("b1:"+b1);//b1:true

    boolean b2 = map.containsKey("赵颖");
    System.out.println("b2:"+b2);//b2:false
}

/*
    public V get(Object key) 根据指定的键,在 Map 集合中获取对应的值。返回值:
            key 存在, 返回对应的 value 值
            key 不存在, 返回 null
 */
private static void show03() {
    // 创建 Map 集合对象
    Map<String,Integer> map = new HashMap<>();
    map.put("赵丽颖",168);
    map.put("杨颖",165);
    map.put("林志玲",178);

    Integer v1 = map.get("杨颖");
    System.out.println("v1:"+v1);//v1:165

    Integer v2 = map.get("迪丽热巴");
    System.out.println("v2:"+v2);//v2:null
}

/*
    public V remove(Object key): 把指定的键 所对应的键值对元素 在 Map 集合中删除,返回被删除元素的值。返回值:V
            key 存在,v 返回被删除的值
            key 不存在,v 返回 null
 */
private static void show02() {
    // 创建 Map 集合对象
    Map<String,Integer> map = new HashMap<>();
    map.put("赵丽颖",168);
    map.put("杨颖",165);
    map.put("林志玲",178);
    System.out.println(map);//{林志玲 =178, 赵丽颖 =168, 杨颖 =165}

    Integer v1 = map.remove("林志玲");
    System.out.println("v1:"+v1);//v1:178

    System.out.println(map);//{赵丽颖 =168, 杨颖 =165}

    //int v2 = map.remove("林志颖");// 自动拆箱  NullPointerException
    Integer v2 = map.remove("林志颖");
    System.out.println("v2:"+v2);//v2:null

    System.out.println(map);//{赵丽颖 =168, 杨颖 =165}
}

/*
    public V put(K key, V value):  把指定的键与指定的值添加到 Map 集合中。返回值:v
            存储键值对的时候,key 不重复, 返回值 V 是 null
            存储键值对的时候,key 重复, 会使用新的 value 替换 map 中重复的 value, 返回被替换的 value 值
 */
private static void show01() {
    // 创建 Map 集合对象, 多态
    Map<String,String> map = new HashMap<>();

    String v1 = map.put("李晨", "范冰冰 1");
    System.out.println("v1:"+v1);//v1:null

    String v2 = map.put("李晨", "范冰冰 2");
    System.out.println("v2:"+v2);//v2: 范冰冰 1

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

    map.put("冷锋","龙小云");
    map.put("杨过","小龙女");
    map.put("尹志平","小龙女");
    System.out.println(map);//{杨过 = 小龙女, 尹志平 = 小龙女, 李晨 = 范冰冰 2, 冷锋 = 龙小云}
}

}

正文完
 0