map<K,V>:将键(k)映射到值(v)的对象,通过键可以找到对应的值
Map集合的特点:
1、双列集合,一个元素包含两个值(key-Value)
2、key和value类型可以相同,也可以不同
3、key和value是一一对应的
4、key不允许重复,value是可以重复的
常用实现类:
HashMap<K,V> implements Map<K,v>接口
特点:
1、底层是哈希表,查询速度快
JDK1.8之前,数组+单向链表
JDK1.8之后,数组+单向链表/红黑树(链表长度超过8):提高查询的速度
2、元素无序:储存元素和取出元素顺序可能不一致
LinkedHashMap
1、linkedhashmap集合底层是哈希表+链表
2、linkedhashmap集合是一个有序的集合,储存元素和取出元素的顺序是一致的
常用方法:
public V put(K key,V value):把指定的键与指定的值添加到Map集合中
储存键值对的时候,key不重复,返回值v是null
储存键值对的时候,key重复,会使用新的value替换map中重复的value,返回被替换的value值
Map<String,String>map=new HashMap<>();
String v1=map.put("a","A");
v1:null
String v2=map.put("a","aa");
v2:aa
map:[a-aa]
一般用put时,无需接受返回值
map.put("a","A");
map.put("b","B");
map.put("c","C");
map:[a-A,b-B,c-C]
public V remove(Object Key):把指定的键所对应的键值对元素在Map集合中删除,返回被删除元素的值
key存在,v返回被删除的值
key不存在,v返回null,使用包装类接收返回值(防止空指针异常)
建议:使用数据类型时,尽量使用包装类
String s=map.remove("a");
s:A
map:[b-B,c-C]
boolean V containsKey(Object key):判断集合中是否包含指定的键
包含返回true,不包含返回false
boolean b1=map.containsKey("b");true
boolean b2=map.containsKey("e");false
public v get(Object key):根据指定的键,在Map集合中获取对应的值
key存在,返回对应的值
key不存在,返回null
String s1=map.get("b");
String s2=map.get("e");
s1:B
s2:null
public Set<K> keyset():获取Map集合中所有的键,储存到Set集合中
Map集合第一种遍历方式:键找值
keySet()取键放入 set遍历set集合 get
Set<String>set=map.keySet();
for(String s:set){
sout(map.get(s));
}
public Set<Map.Entry<K,V>>entrySet():获取到Map集合中所有键值对对象的集合(Set集合)
entrySet()把entry对象放入set,用getVaule和getKey访问
Set<Map.Entry<String,Integer>>set=map.entrySet();
for(Map.Entrt<String,Integer> entry:set){
sout(entry.getKey()+entry.getValue());
}
HashMap储存自定义类型键值
Map集合保证key是唯一的。作为key的元素,必须重写hashcode和equals方法,以保证key唯一
由于string类型已经重写 了hashcode和equals方法,所以元素不会重复
HashMap<String,Stu>map;
map.put("a",new Stu("1",1));
map.put("b",new Stu("2",2));
map.put("a",new Stu("3",3));
map:b 2 2,a 3 3
HashMap<Stu,String>map;
map.put(new Stu("a",1),a);
map.put(new Stu("a",1),b);
//如果以自定义类型为键,那么在自定义类中要重写hashcode和equals方法,防止重复
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Stu stu = (Stu) o;
return age == stu.age && Objects.equals(name, stu.name);
}
@Override
public int hashCode() {
return Objects.hash(name, age);
}
LinkedHashMap:
1、继承了HashMap类
2、底层原理:哈希表+链表(记录元素顺序),所以LinkedHashMap是有序的(存入和取出顺序一致)
LinkedHashMap<String,String>map=new LinkedHashMap<>();
map.put("c",c);
map.put("a",a);
map:c-c,a-a
Hashtable:
1、底层是一个哈希表,是一个线程安全的集合,是单线程集合,速度慢
2、不可以存储null值,null键(其他的hash集合可以)
3、JDK1.2之后已经被HashMap取代