1:Map集合的特征
1:通过键值对
2:key和value都可以为任意类型
3:key可以重复,但是后面的会覆盖前面的
4:value可以重复
5:key可以为null但是只能有一个,同样多个null,后面覆盖前面的,value可以多个为null
6:Map的key在底层可以理解为Set
2:常用方法
package com.API_Map;
import java.util.Collection;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Set;
public class MapTest {
// key值具有唯一性
public static void main(String[] args) {
HashMap<String ,String> map = new HashMap<>();
map.put("高启强","陈书婷");
map.put("张青","孙二娘");
//取张青他的妻子
// 取出所有的key
Set<String> keys = map.keySet();
for (String s :
keys) {
System.out.println(s);
//拿value的值
System.out.println(map.get(s));
}
String value = map.get("高启强");
Collection<String> values = map.values();
Iterator<String> iterator = values.iterator();
while(iterator.hasNext()){
System.out.println(iterator.next());
}
}
}
//6 获取Map中键的集合和值得集合
// System.out.println("map中key的集合:"+map.keySet());
// System.out.println("map中value的集合:"+map.values());
3:HashMap-哈希表:数组+链表+红黑树
实现原理:
如同HashSet一样,先利用hashcode计算出一个值,查找数组是否含有元素,含有就利用equals方法进行判断,不重复就留在链表的末尾,重复就覆盖
4:HashMap的遍历-keySet(),entrySet
1:keySet():
Set keys = map.keySet();
Iterator iterator = keys.iterator();
while(iterator.hasNext()){
Object key = iterator.next();
Object val = map.get(key);
}
2:entrySet:
Set entrySet = map.entrySet();
Iterator iterator = entrySet.iterator();
while(iterator.hasNext()){
Map.Entry entry = (Map.Entry)iterator.next();
Object key = entry.getKey();
Object value = entry.getValue();
}
Set<Map.Entry<Character, Integer>> entrys = map.entrySet();
for (Map.Entry<Character, Integer> entry :
entrys) {
Character key = entry.getKey();
Integer value = entry.getValue();
}
5:HashMap与HashTable的区别
HashMap:线程不安全,key和value都能为null、
HashTable:线程安全,key和value都不能为null、
6:总结
Map接口中大多数是hash方法进行实现的,
独特的entrySet方法进行HashMap的遍历
7:建议采纳
如有建议或者错误请私信我进行修改,感谢!