List<Long> tempList = smokeAreas.stream().map(SmokeArea::getAreaId).collect(Collectors.toList());的技术是什么
时间: 2024-05-31 21:13:54 浏览: 82
这行代码使用了Java 8中的Stream API和Lambda表达式技术。
具体来说,`smokeAreas`是一个对象列表,`SmokeArea`是一个Java Bean,其中包含`areaId`属性。
这行代码使用了Stream API中的`map()`方法,它将每个`SmokeArea`对象映射为其`areaId`属性,并返回一个由这些属性组成的新的Stream。
接下来,使用`collect()`方法,将这些`areaId`属性收集到一个新的`List`对象中,这个新的`List`对象就是代码中的`tempList`。
Lambda表达式则是用来作为`map()`方法中的参数,用来描述如何从每个`SmokeArea`对象中提取`areaId`属性。
相关问题
List<Long> tempList = smokeAreas.stream().map(SmokeArea::getAreaId).collect(Collectors.toList());的意思
这段代码的意思是将一个 `SmokeArea` 类型的列表中的每个对象的 `areaId` 属性提取出来,组成一个 `Long` 类型的列表。具体来说,`map(SmokeArea::getAreaId)` 表示将列表中每个 `SmokeArea` 对象的 `areaId` 属性作为参数传递给 `map` 方法的参数,`Collectors.toList()` 则表示将 `map` 方法的返回结果收集到一个 `List` 集合中并返回。最终的结果是一个 `Long` 类型的列表,其中的元素是 `SmokeArea` 对象列表中每个对象的 `areaId` 属性。
public List<SmokeArea> buildSmokeAreaTree(List<SmokeArea> smokeAreas){ List<SmokeArea> returnList = new ArrayList<>(); List<Long> tempList = smokeAreas.stream().map(SmokeArea::getAreaId).collect(Collectors.toList()); for(SmokeArea smokeArea : smokeAreas){ //如果顶级节点,遍历发该父节点的所有子节点 if (!tempList.contains(smokeArea.getParentId())){ recursionFn(smokeAreas,smokeArea); returnList.add(smokeArea); } } if (returnList.isEmpty()){ returnList = smokeAreas; } return returnList; } public List<TreeSelect> buildSmokeAreaTreeSelect(List<SmokeArea> smokeAreas){ List<SmokeArea> smokeAreaTrees = buildSmokeAreaTree(smokeAreas); return smokeAreaTrees.stream().map(TreeSelect::new).collect(Collectors.toList()); } private void recursionFn(List<SmokeArea> list, SmokeArea smokeArea){ //得到子节点列表 List<SmokeArea> childList = getChildList(list,smokeArea); smokeArea.setChildren(childList); for (SmokeArea sChild : childList) { if (hasChild(list,sChild)){ recursionFn(list,sChild); } } } private List<SmokeArea> getChildList(List<SmokeArea> list ,SmokeArea smokeArea){ List<SmokeArea> slist = new ArrayList<>(); Iterator<SmokeArea> it = list.iterator(); while (it.hasNext()){ SmokeArea s = (SmokeArea) it.next(); if (StringUtils.isNotNull(s.getParentId()) && s.getParentId().longValue() == smokeArea.getAreaId().longValue()){ slist.add(s); } } return slist; } private boolean hasChild(List<SmokeArea> list, SmokeArea smokeArea){return getChildList(list,smokeArea).size() > 0;} 帮我解释一下这段代码
这段代码实现了将一组SmokeArea对象构建成树形结构的功能。其中SmokeArea是一个烟区对象,具有一个编号areaId和一个父节点编号parentId。该方法的输入参数是一个SmokeArea对象列表,输出结果是一个树形结构的SmokeArea对象列表。具体实现过程如下:
1. 先创建一个空的返回结果列表 returnList,并创建一个 tempList,用于暂存所有SmokeArea对象的编号 areaId。
2. 遍历传入的 SmokeArea 列表 smokeAreas,对于每个SmokeArea对象,如果它的父节点编号 parentId 不在 tempList 中,则说明它是一个顶级节点,需要从它开始递归遍历其所有子节点。递归遍历的过程中,将每个遍历到的 SmokeArea 对象放入 returnList 中。
3. 如果 returnList 仍然是空的,则说明所有SmokeArea对象都是顶级节点,直接将 smokeAreas 赋值给 returnList。
4. 最后,将 returnList 中的 SmokeArea 对象转化为 TreeSelect 对象并返回。其中 TreeSelect 是一个树形结构的下拉列表对象,用于在前端页面中显示。
5. 递归遍历的具体实现是一个私有方法 recursionFn,它接收两个参数,一个是 SmokeArea 对象列表 list,另一个是当前正在递归遍历的 SmokeArea 对象 smokeArea。它的作用是找到 smokeArea 的所有子节点,并将它们放入 smokeArea 的 children 属性中。
6. 找到 smokeArea 的所有子节点的方法是 getChildList,它接收两个参数,一个是 SmokeArea 对象列表 list,另一个是当前正在递归遍历的 SmokeArea 对象 smokeArea。它的作用是从 list 中找到所有 parentId 等于 smokeArea 的 areaId 的 SmokeArea 对象,将它们放入一个列表中并返回。
7. 判断一个 SmokeArea 对象是否有子节点的方法是 hasChild,它接收两个参数,一个是 SmokeArea 对象列表 list,另一个是当前正在递归遍历的 SmokeArea 对象 smokeArea。它的作用是判断 getChildList(list, smokeArea) 的返回值列表的长度是否大于0,如果大于0,则说明 smokeArea 有子节点,否则没有子节点。
阅读全文