上一篇讲完 collection接口,这篇我们来学习 map接口,map接口 也是一个很重要的容器。
map接口 里面的内容都是 键值对,一个key对应一个value。key不可以重复、value可以重复。Map的key一遍都是String。 让我们看看API对此接口的描述:
Map 接口提供三种collection 视图,允许以 键集、值集 或 键-值映射关系集 的形式查看某个映射的内容。映射顺序定义为迭代器在映射的 collection 视图上返回其元素的顺序。某些映射实现可明确保证其顺序,如 TreeMap类;另一些映射实现则不保证顺序,如 HashMap 类。
视图是什么??
视图其实就是一个集合,但是是一个不能修改的集合,只能对视图进行查询和遍历操作。
Map接口的方法:
- void clear()
从此映射中移除所有映射关系(可选操作)。 - boolean containsKey(Object key)
如果此映射包含指定键的映射关系,则返回 true。 - boolean containsValue(Object value)
如果此映射将一个或多个键映射到指定值,则返回 true。 - Set<Map.Entry<K,V>> entrySet()
返回此映射中包含的映射关系的 Set 视图。 - boolean equals(Object o)
比较指定的对象与此映射是否相等。 - V get(Object key)
返回指定键所映射的值;如果此映射不包含该键的映射关系,则返回 null。 - int hashCode()
返回此映射的哈希码值。 - boolean isEmpty()
如果此映射未包含键-值映射关系,则返回 true。 - Set keySet()
返回此映射中包含的键的 Set 视图。 - V put(K key, V value)
将指定的值与此映射中的指定键关联(可选操作)。 - void putAll(Map<? extends K,? extends V> m)
从指定映射中将所有映射关系复制到此映射中(可选操作)。 - V remove(Object key)
如果存在一个键的映射关系,则将其从此映射中移除(可选操作)。 - int size()
返回此映射中的键-值映射关系数。 - Collection values()
返回此映射中包含的值的 Collection 视图。
Map的遍历:
- 使用 keySet
Set<String> set=map.keySet();
for(String key:set){
System.out.println(key+":"+map.get(key));
}
- 使用 collection
Collection<String> collection=map.values();
for(String str:collection){
System.out.println(str);
}
- 使用 Map.Entry(Map.Entry接口,也就是一直所说的键值对,这个接口是Map中元素需要实现的接口。)
Set<String> set=map.keySet();
for(Entry<String,String> entry:map.entrySet()){
System.out.println(entry.getKey()+":"+entry.getValue());
}
来看个例子:
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
public class Bianli
{
public static void main(String[] args)
{
Map<String, String> map=new HashMap<>();
map.put("aa", "Animal");
map.put("bb", "Dog");
map.put("cc", "Cat");
map.put("cc", "Cat");//重复元素
// 使用 keySet遍历
Set<String> set=map.keySet();
for(String key : set)
{
System.out.println(key + ":" + map.get(key));
}
// 使用 collection 遍历
Collection<String> collection=map.values();
for(String str : collection)
{
System.out.println(str);
}
// 使用 Map.Entry遍历
for(Entry<String, String> entry : map.entrySet())
{
System.out.println(entry.getKey() + ":" + entry.getValue());
}
}
}
执行结果:
TreeMap
TreeMap相对于Hash Map来说,增加了排序功能。
TreeMap的key是通过Comparable接口 过滤重复 排序,也可以通过Comparator接口的实现类的对象来过滤重复排序
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import java.util.TreeMap;
public class Bianli
{
public static void main(String[] args)
{
Map<String, String> map=new TreeMap<>();
map.put("aa", "Animal");
map.put("cc", "Cat");
map.put("bb", "Dog");
map.put("cc", "Cat");
Set<String> set=map.keySet();
for(Entry<String, String> entry : map.entrySet())
{
System.out.println(entry);
}
}
}