ws.schild.jave.inputformatexception: null
时间: 2023-05-08 16:59:24 浏览: 212
这是一个Java程序的异常信息,表示在解析输入格式时出现了问题,具体问题是空指针异常(NullPointerException)。通常出现这种异常的原因是输入的数据格式不符合程序预期,或者输入数据为空。解决此问题的方法是检查输入的数据是否为非空且符合程序要求的格式,可以添加一些输入数据验证的代码来避免这种异常的发生。另外,还可以对程序进行一些调试和优化,以提高程序的健壮性和稳定性。
相关问题
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 有子节点,否则没有子节点。
阅读全文