Map集合的特点
将键映射到值的对象,一个映射不能包含重复的键,每个键只能映射到一个值。
Map集合和Collection集合的区别?
- Map集合存储元素是成对出现的,Map的键是唯一的,值是可重复的。
- Collection集合存储元素是单独出现的,Collection的子类Set是唯一,不可重复,List是可重复的。
- Map集合的数据结构只针对键有效,和值无关。
- Collection集合的数据结构对元素有效。
常用Api
- 添加功能
V put(K key,V value):
添加元素。这里的返回值是如果Key键不存在,返回值为null,如果Key键存在Map中,就会把上一次Key对应的值返回。 - 删除功能
void clear():移除所有键值对元素。
V remove(Object key):根据键删除键值对元素,并把元素返回。 - 判断功能
boolean containsKey(Object key): 判断集合是否包含指定的键。
boolean containsValue(Object value):判断集合是否包含指定的值。 - 获取功能
Set<Map.Entry<K,V>> entrySet:返回键值对对象
V get(Object key):根据键获取值,不存在则返回null
Set<K> keySet():获取集合中所有键的集合
Collection<V> values()获取集合中所有值的集合
(这里可以看出Map的键是由Set接口实现,值由Collection接口实现)
- 长度功能
int size():返回集合中的键值对的对数。
例子
/**
*
* @author loveqRc
*
* 需求 :"aababcabcdabcde",获取字符串中每一个字母出现的次数要求结 果:a(5)b(4)c(3)d(2)e(1)
* 从输出结果看:第一排序:所以用Tree 。
* 第二元素唯一,也就是abcd..中同一个字母只会出现一次,决定用TreeSet或TreeMap。
* 第三是以键值对方式显示最后决定用TreeMap。
*
*/
public class MapDemo {
public static void main(String[] args) {
TreeMap<Character, Integer> tm = new TreeMap<Character, Integer>();
Scanner scanner=new Scanner(System.in);
System.out.println("请输入一段字符串:");
String line = scanner.nextLine();
char[] charArray = line.toCharArray();
for (char c : charArray) {
Integer integer = tm.get(c);
if (integer==null) {//如果tm中没有就返回null
tm.put(c, 1);
}else{
integer++;
tm.put(c, integer);
}
}
StringBuilder sb=new StringBuilder();
Set<Character> keySet = tm.keySet();
for (Character character : keySet) {
Integer integer = tm.get(character);
sb.append(character).append("(").append(integer).append(")");
}
System.out.println("result:"+sb.toString());
//result:a(5)b(4)c(3)d(2)e(1)
}
}