有时候经常用到map的KV对,但是在遍历的时候经常忘记如何去实现,所以做一个笔记,留作后面的回顾;
public static void main(String[] args) {
String msg = "can you can a can as a can canner can a can.";
Map<Character, Integer> str = new HashMap<Character, Integer>();
for(Character c:msg.toCharArray()){
Integer number = str.getOrDefault(c,0);
str.put(c,number+1);
}
//lambda表达式
//map遍历
str.forEach((Character c,Integer num)->{
System.out.print(c+"="+num+",");
});
}
还有就是经常要存入某个元素个数,一般是先判断元素是否存在,再分类讨论,但是其实可以参考上面的,直接调用getOrDefault(x,0)的方法,存在就是n+1插进去,不存在则是n+1=1插入;相比之前直接用get()返回null,以及使用containsKey()返回布尔值好许多;