Stream流式计算是java8中一个非常成功的改进,它为我们操作集合(Collection)提供了极大的便利。使用stream,我们可以像操作数据库一样对将要处理的元素集合进行筛选、聚合、转换等操作。
以笔者工作中遇到的一个问题为例:
给定一个列表:
public class Entity1{
String id;
String area;
String type;
String text;
String extra;
}
List<Entity1>
根据area和type进行分类,形成多级map结构:
Map<area, Map<type, Entity1>>
传统方法实现:
//给定的列表从getResList()中获取
List<Entity1> resList = getResList();
//目标map
Map<String, Map<String, Entity1>> map1 = new HashMap<String, Map<String, Entity1>>();
for (int i=0;i<resList.size();i++){
Entity1 entity = resList.get(i);
Map<String,Entity1> subMap = map1.get(entity.get(area));
subMap.put(entity.get(type), entity);
map1.put(entity.get(area), subMap);
}
可以看到这里要做的操作非常多,随着层数的增加,需要维护的对象个数直线上升。
Stream 实现:
//目标map
Map<String, Map<String,Entity1>> map2 = getResList().stream.collect(
Collectors.groupingBy(Entity1::getArea(),
Collectors.groupingBy(Entity1::getType)));
在流式处理中,这儿的groupingBy还可以无限套娃,非常方便!
stream的更多用法,如映射,排序等,后续将在系列中一一讲解!