# 集合-Map

🐴

# 前言

Map集合是一种键值对(key-value) 类型的集合(类似于json数据种的对象)。 再Map集合中,Key不允许重复。

Map接口的实现类主要有两个:

  • HashMap 类可以按哈希算法来存取键对象
  • TreeMap 类可以对键对象进行排序

# 常用方法

Map接口常用的方法如下:

方法 描述
void clear() 删除该 Map 对象中的所有 key-value 对。
boolean containsKey(Object key) 查询 Map 中是否包含指定的 key,如果包含则返回 true
boolean containsValue(Object value) 查询 Map 中是否包含一个或多个 value,如果包含则返回 true
V get(Object key) 返回 Map 集合中指定键对象所对应的值。V 表示值的数据类型
V put(K key, V value) 向 Map 集合中添加键-值对,如果当前 Map 中已有一个与该 key 相等的 key-value 对,则新的 key-value 对会覆盖原来的 key-value 对。
void putAll(Map m) 将指定 Map 中的 key-value 对复制到本 Map 中。
V remove(Object key) Map 集合中删除 key 对应的键-值对,返回 key 对应的 value,如果该 key 不存在,则返回 null
boolean remove(Object key, Object value) 这是 Java 8 新增的方法,删除指定 keyvalue 所对应的 key-value 对。如果从该 Map 中成功地删除该 key-value 对,该方法返回 true,否则返回 false
Set entrySet() 返回 Map 集合中所有键-值对的 Set 集合,此 Set 集合中元素的数据类型为 Map.Entry
Set keySet() 返回 Map 集合中所有键对象的 Set 集合
boolean isEmpty() 查询该 Map 是否为空(即不包含任何 key-value 对),如果为空则返回 true
int size() 返回该 Mapkey-value 对的个数
Collection values() 返回该 Map 里所有 value 组成的 Collection

# HashMap

HashMap是无序的,根据键的 HashCode 值存储数据,具有很快的访问速度,不支持线程同步

import java.util.Arrays;
import java.util.HashMap;
import java.util.Set;

public static void main(String[] args){
  HashMap hm = new HashMap();
  // 添加元素
  hm.put("8","小王");
  hm.put("5","小牛");
  hm.put("3","小李");
  hm.put("7","小赵");

  System.out.println(hm.size()); // 4
  // 获取值
  System.out.println(hm.get("5")); // 小牛
  // 删除
  hm.remove("5");
  System.out.println(hm.size()); // 3
  System.out.println(hm.containsKey("5")); // false
  // 获所有key
  Set key = hm.keySet();
  //[3, 7, 8]
  System.out.println(Arrays.toString(key.toArray()));
}

# TreeMap

TreeMap是有序的,根据键进行排序。TreeMap的用法和HashMap基本一样

TreeMap tm = new TreeMap();
// 添加元素
tm.put("8","小王");
tm.put("5","小牛");
tm.put("3","小李");
tm.put("7","小赵");

// 获所有key
Set key = tm.entrySet();

//[3=小李, 5=小牛, 7=小赵, 8=小王]
System.out.println(Arrays.toString(key.toArray()));

# Hashtable

HashtableHashMap一样都实现了Map接口,都是键值对保存数据的方式。并且用法基本一样,它们的主要区别:

  • Hashtable不能存放null, HashMap可以存放null
  • Hashtable是线程安全的, HashMap不是线程安全的
最近更新时间: 7/2/2021, 11:27:27 AM