统计List集合中元素出现的次数,相信大家都做过。举个例子,我们要统计集合中名字重复的次数。
List<String> nameLists = Arrays.asList("Lvshen", "Lvshen", "Zhouzhou", "Huamulan", "Huamulan", "Huamulan");
一般我们会这么做:
Map<String, Integer> nameMap = Maps.newHashMap();
nameLists.forEach(name -> {
Integer counts = nameMap.get(name);
nameMap.put(name, counts == null ? 1 : ++counts);
});
System.out.println(nameMap);
首先创建一个map,然后遍历list,把list元素作为map的key,初始的value设置为1,如果遍历到重复的key,value加1,这样我们就统计出想要的结果了。

上面是我们通常的做法,相信大家都这样做过。
Java8后我么又有了新的统计方法,我们可以使用stream()一步到位。
Map<String, Long> nameMap = nameLists.stream().collect(Collectors.groupingBy(p -> p, Collectors.counting()));
运行结果如下:

上面的代码就是对集合中的元素进行分组统计,是不是像SQL的统计方法呢。
select key,count(key) from table group by key;
Java8还有其他的统计方式:
Map<String, Integer> nameMap = Maps.newHashMap();
nameLists.forEach(name -> nameMap.compute(name, (k, v) -> v == null ? 1 : ++v));
使用compute和方法一类似,但是这里少个get获取这一步骤。

进入compute方法,我们发现里面有获取原有值这一项:
V oldValue = get(key);
然后在旧值的基础上操作获取新值:
V newValue = remappingFunction.apply(key, oldValue);
好了今天的Java8小知识分享就到这里了。下次我们再来分享其他Java8的小知识。