Map集合
一、概念
- Map用于保存具有映射关系的数据,因此Map集合里保存着两组值,一组值用于保存Map里的Key,另外一组用于保存Map里的Value。
- Map中的可以和value都可以是任何引用类型的数据
- Map中的Key不允许重复。即同一个Map对象的任何两个Key通过equals方法比较总返回false。
- Key和Value之间存在单项一对一关系。即通过指定的Key总能找到唯一的,确定的Value。
二、Map和HashMap
1、map的基本方法使用
import java.util.HashMap;
import java.util.Map;
public class test{
public static void main(){
Map<String,Integer> map = new HashMap<String,Integer>();
map.put("b",1);
map.put("c",2);
map.put("e",2);
System.out.println(map);
System.out.println(map.get("b"));
map.remove("c");
System.out.println(map);
System.out.println(map.size());
System.out.println(map.containsKey("a"));
System.out.ptintln(map.containsValue(10));
map.clear();
for(String key : keys){
System.out.println(“key: ” + key + ", value: " + map.get(key));
}
Set<Entry<String,Integer>> entrys = map.entrySet();
for(Entry<String,Integer> en : entrys){
System.out.println("key: " + en.getKey() + ", value: " + en.getValue());
}
}
}
2、HashMap & Hashable
- HashMap和Hashtable是Map接口的两个典型实现类
- 区别
- Hashtable是一个古老的map实现类,不建议使用
- Hashtable是一个线程安全的Map实现,但HashMap是线程不安全的
- Hashtable不允许使用null作为key和value,而HashMap可以
- 与HashSet集合不能保证元素的顺序一样,而Hashtable、HashMap也不能保证其中key-value对的顺序
- Hashtable、HashMap判断两个Key相等的标准是:两个Key通过equals方法返回true,hashCode值也相等
- Hashtable、HashMap相等的标准是:两个Value通过equalHashMap判断两个Values方法返回true
3、TreeMap
- TreeMap存储Key-Value对时,需要根据Key对key-value对进行排序。TreeMap可以保证所有的Key-Value对处于有序状态
- TreeMap的Key 的排序
- 自然排序:TreeMap的所有的Key必须实现Comparable接口,而且所有的Key应该是同一个类的对象,否则将会抛出ClassCastException
- 定制排序:创建TreeMap时,传入一个Comparator对象,该对象负责对TreeMap中的所有key进行排序。此时不许需要Map的Key实现Comparable接口
- TreeMap的自然排序是字典排序