1、集合框架Map介绍 map集合中存放的都是一组组映射关系 key=value Map集合中允许嵌套 map集合Key不能重复,
1、增加 put(K key, V value) putAll(Map<? extends K,? extends V> m) 1.添加集合元素的同时 它可以编辑原有的元素 如果说集集合中没有Key对应的value,那么就往集合中添加元素 如果说集合中对应的Key有value值,则代表替换原有的值 2.返回替换前Key对应的value值 **替换前**替换后
Map : ( Hashtable TreeMap ) Hashtable:底层是哈希表数据结构,不可以存入null键null值,该集合石线程同步的,jdk1.0,效率低 HashMap:底层是哈希表数据结构,允许使用null值和null键,该集合是不同步的。将Hashtable替代;jdk1.2,效率高 TreeMap:底层是二叉树数据结构,线程不同步,可以用于给Map集合中的键进行排序TreeMap是通过hasCode , equals的方法进行去重复的 比如,将学生作为键,地址作为值进行存储,名字年龄相同则被认定为一个人. (前提是都写了实体类)
public int HashCode() { return this.getName().hashCode()+this.getAge()*39 ; } @Override public boolean equals(Object obj) { Student stu=(Student) obj; return this.getAge()== stu.getAge()&&this.getName().equals(stu.getName()); } 2、删除 clear() remove(Object key) 3、判断 containsKey(Object key) containsValue(Object value) isEmpty() 4、获取 get(Object key) size() values() entrySet() keySet() Map集合映射关系May.Entry描述的伪代码2、集合框架Map应用
应用一: 1、将学生作为键,地址作为值进行存储,名字年龄相同则被认定为一个人,最后输出然后在main方法遍历
应用二: 统计字符串中字符出现次数统计功能
1,将这个字符串转为数组,将这个字符串中的字符当做map集合的Key将出现字符作为Value值 2,当字符第一次出现的时候,那么用他在集合进行寻找,返回值必然为null,之后 将该字符对应的值修改为1 3,如果说该字符不是第一次出现,该字符对应值不为null,然后+1 public static void main(String[] args) { String str="ffdgfdkdjghggdgxcdgfdgcvxcxczc"; str=chishu(str); System.out.println(str); } public static String chishu(String str) { char[] charArray = str.toCharArray(); Map<Character, Integer> map=new TreeMap<>(); for (char c : charArray) { Integer value = map.get(c); if(value==null) { map.put(c,1); }else { map.put(c, ++value); } } StringBuffer sb=new StringBuffer(); for (Map.Entry<Character,Integer> entry: map.entrySet()) { sb.append(entry.getKey()+"("+entry.getValue()+")"); } return sb.toString(); }