Java学习笔记--Map接口

来源:互联网 发布:行业专用软件 编辑:程序博客网 时间:2024/04/27 18:19

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)    }}
0 0
原创粉丝点击