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, 冷锋 = 龙小云}
}
}