示例:
package com.igeek02;
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
/*
* java.util
接口 Map<K,V>
K: key 键的类型
V:value 值的类型
将键映射到值的对象。一个映射不能包含重复的键;每个键最多只能映射到一个值。
此接口取代 Dictionary 类,后者完全是一个抽象类,而不是一个接口。
Map中存储的元素:键值对对象
特点:键是唯一的,一个键对应一个值
不同的键可以对应同一个值(值是可以重复的)
学号 姓名
3001 张三
3002 李四
3003 张三
映射关系/Map中的元素/键值对
Map :键是唯一的
底层数据结构的特性只针对键有效的
---HashMap: 底层是哈希表 键唯一的
---TreeMap: 底层是二叉树 键唯一,排序
常用方法
方法摘要
添加
V put(K key, V value)
将指定的值与此映射中的指定键关联(可选操作)。
void putAll(Map<? extends K,? extends V> m)
从指定映射中将所有映射关系复制到此映射中(可选操作)。
清除
void clear()
从此映射中移除所有映射关系(可选操作)。
V remove(Object key)
如果存在一个键的映射关系,则将其从此映射中移除(可选操作)。
判断
boolean containsKey(Object key)
如果此映射包含指定键的映射关系,则返回 true。
boolean containsValue(Object value)
如果此映射将一个或多个键映射到指定值,则返回 true。
boolean isEmpty()
如果此映射未包含键-值映射关系,则返回 true。
Map集合遍历 Map.Entry<K,V>:键值对对象所对于的类
Set<Map.Entry<K,V>> entrySet()
返回此映射中包含的映射关系的 Set 视图。
获取
V get(Object key)
返回指定键所映射的值;如果此映射不包含该键的映射关系,则返回 null。
Set<K> keySet()
返回此映射中包含的键的 Set 视图。
Collection<V> values()
返回此映射中包含的值的 Collection 视图。
int size() 集合中的元素个数
返回此映射中的键-值映射关系数。
* */
public class Demo1 {
public static void main(String[] args) {
Map<Integer, String> map = new HashMap<Integer, String>();
// V put(K key, V value) 将指定的值与此映射中的指定键关联(可选操作)。
System.out.println(map.put(3001, "张三"));//null 添加元素时,如果键不存在的,直接添加,并且返回null
System.out.println(map);//{3001=张三}
System.out.println(map.put(3001, "李四"));//添加元素时,如果键已经存在,使用新的值替换原先的值,并且返回被替换的值
System.out.println(map);
System.out.println(map.put(3002, "张三"));
System.out.println(map);//{3001=李四, 3002=张三}
Map<Integer, String> map1 = new HashMap<Integer, String>();
map1.put(3003, "杨幂");
map1.put(3002, "刘诗诗");
map.putAll(map1);
System.out.println(map);//{3001=李四, 3002=刘诗诗, 3003=杨幂}
System.out.println("-------");
// V remove(Object key)
// 如果存在一个键的映射关系,则将其从此映射中移除(可选操作)。
System.out.println(map.remove(3001));//如果键存在,删除该键对应的键值对,同时返回键对应的值
System.out.println(map.remove(""));//如果键不存在,直接返回null
System.out.println(map);//{3002=刘诗诗, 3003=杨幂}
//map.clear();//清除所有的键值对对象(元素)
//System.out.println(map);//{}
System.out.println("-----判断-----");
System.out.println(map.isEmpty());
System.out.println(map.containsKey(3002));
System.out.println(map.containsKey(""));
System.out.println(map.containsValue("刘诗诗"));
System.out.println("----------");
System.out.println(map.size());
System.out.println(map.get(3003));
System.out.println("-------遍历集合的第一种方式------------");
/*
* 1、获取键的集合
* 2、遍历键的集合,取出每一个键
* 3、根据键获取值
*
* Set<K> keySet()
返回此映射中包含的键的 Set 视图。
V get(Object key)
返回指定键所映射的值;如果此映射不包含该键的映射关系,则返回 null。
Collection<V> values()
返回此映射中包含的值的 Collection 视图。
* */
Set<Integer> keys = map.keySet();//获取所有键的集合
//遍历键的集合
Iterator<Integer> it = keys.iterator();
while(it.hasNext()) {
//获取键
Integer key = it.next();
//根据键获取值
String value = map.get(key);
//输出键值对
System.out.println(key + "-->" + value);
}
System.out.println();
Collection<String> values = map.values();
for (String value : values) {//遍历所有的值
System.out.println(value);
}
System.out.println("-------遍历集合的第二种方式------------");
/*
* 1、获取所有键值对对象的集合
* 2、遍历该集合,获取每一个键值对对象
* 3、根据键值对对象分别获取键和值
*
* 键值对对象对应的类
* 模拟源码
* interface Map<K,V> {
* //内部类
* class Entry<K,V>{//Entry即键值对对象所对应的类
* K key;
* V value;
* //获取键
* K getKey(){
* return key;
* }
* //获取值
* V getValue(){
* return value;
* }
* }
* }
*
* 键值对对象的类型:Map.Entry<K,V>
* Set<Map.Entry<K,V>> entrySet()
返回此映射中包含的映射关系的 Set 视图。
*
* */
//1、获取所有键值对对象的集合
Set<Map.Entry<Integer, String>> entrys = map.entrySet();//
//2、遍历该集合,获取每一个键值对对象
Iterator<Map.Entry<Integer, String>> it1 = entrys.iterator();
while(it1.hasNext()) {
Map.Entry<Integer, String> element = it1.next();//获取的每一个键值对对象
Integer key = element.getKey();
String value = element.getValue();
System.out.println(key + "-->" + value);
}
}
}