pageInfo<VO> info = new PageInfo<>(VoList)
时间: 2023-11-16 07:17:41 浏览: 25
这是一个使用CSDN开发的分页功能的示例代码。在这段代码中,`VoList`是一个包含数据的列表,`VO`是数据的类型。通过创建一个`PageInfo`对象,我们可以将`VoList`中的数据进行分页处理。这个`PageInfo`对象包含了关于分页信息的元数据,比如总页数、当前页码等。这样,我们可以方便地对大量数据进行分页展示和处理。
相关问题
/**循环递归**/ public List<PrpdCompanyVo> deptList(String comCode) { /**查询指定公司代码的**/ List<PrpdCompanyPo> list0 = this.selectByPid(comCode); PrpdCompanyVo prpdCompanyVo = new PrpdCompanyVo(); prpdCompanyVo.setComCode(comCode); prpdCompanyVo.setIsEnable("Y"); if(CollectionUtils.isEmpty(list0)){ List<PrpdCompanyVo> listVo = new ArrayList<>(); listVo.add(prpdCompanyVo); return listVo; //根节点是空 //返回自己 } List<PrpdCompanyVo> voList=list0.stream().map(this::converVO).collect(Collectors.toList()); List<PrpdCompanyVo> voListBackup =list0.stream().map(this::converVO).collect(Collectors.toList()); voListBackup.forEach(item-> buildChild(item,voList)); return voList; } private void buildChild(PrpdCompanyVo item, List<PrpdCompanyVo> voListO){ List<PrpdCompanyPo> listChild = this.selectByPid(item.getComCode()); if(CollectionUtils.isEmpty(listChild)){ voListO.add(item); return; } List<PrpdCompanyVo> voList=listChild.stream().map(this::converVO).collect(Collectors.toList()); item.setChildList(voList); voList.forEach(item2-> buildChild(item2,voListO)); } private PrpdCompanyVo converVO(PrpdCompanyPo po){ PrpdCompanyVo VO = new PrpdCompanyVo(); BeanUtils.copyProperties(po,VO); return VO; } 请优化这段代码
在给出代码的优化之前,我注意到在 `buildChild` 方法中,您使用了 `selectByPid` 方法来查询子部门列表,但在 `deptList` 方法中也使用了相同的方法来查询下级公司列表。这可能会导致在构建子部门列表时重复查询相同的数据,导致性能下降。
为了优化代码,我建议您在 `deptList` 方法中先查询一次下级公司列表,并将其作为参数传递给 `buildChild` 方法。这样可以避免重复查询数据,提高代码效率。
另外,您在 `buildChild` 方法中使用了两个列表 `voList` 和 `voListO` 来存储子部门列表和结果列表。这样会导致内存占用较高。为了优化内存使用,您可以将 `voList` 和 `voListO` 合并为一个列表,并在每次递归调用 `buildChild` 方法之前,先将子部门列表添加到结果列表中。
以下是优化后的代码示例:
```java
public List<PrpdCompanyVo> deptList(String comCode) {
List<PrpdCompanyPo> list0 = this.selectByPid(comCode);
PrpdCompanyVo prpdCompanyVo = new PrpdCompanyVo();
prpdCompanyVo.setComCode(comCode);
prpdCompanyVo.setIsEnable("Y");
if (CollectionUtils.isEmpty(list0)) {
List<PrpdCompanyVo> listVo = new ArrayList<>();
listVo.add(prpdCompanyVo);
return listVo;
}
List<PrpdCompanyVo> voList = list0.stream().map(this::converVO).collect(Collectors.toList());
buildChild(voList, voList);
return voList;
}
private void buildChild(List<PrpdCompanyVo> itemList, List<PrpdCompanyVo> result) {
List<PrpdCompanyVo> childList = new ArrayList<>();
for (PrpdCompanyVo item : itemList) {
List<PrpdCompanyPo> listChild = this.selectByPid(item.getComCode());
if (CollectionUtils.isEmpty(listChild)) {
result.add(item);
} else {
List<PrpdCompanyVo> voList = listChild.stream().map(this::converVO).collect(Collectors.toList());
item.setChildList(voList);
childList.addAll(voList);
}
}
if (!childList.isEmpty()) {
buildChild(childList, result);
}
}
private PrpdCompanyVo converVO(PrpdCompanyPo po) {
PrpdCompanyVo vo = new PrpdCompanyVo();
BeanUtils.copyProperties(po, vo);
return vo;
}
```
在优化后的代码中,我们将 `voList` 和 `voListO` 合并为一个列表 `result`,并将子部门列表 `childList` 用于存储待处理的子部门。在每次递归调用 `buildChild` 方法之前,将子部门列表添加到结果列表 `result` 中。
这样就避免了重复查询数据,并且减少了内存占用。希望这个优化能对您有所帮助!如果您有其他问题,请随时提问。
list<VO> 转为 Map<String, List<String>>
可以使用Java 8的流(Stream)来将List<VO>转换为Map<String, List<String>>。下面是一个示例代码:
```java
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
public class Main {
public static void main(String[] args) {
List<VO> voList = getListOfVO(); // 假设这是一个List<VO>的实例
Map<String, List<String>> resultMap = voList.stream()
.collect(Collectors.groupingBy(VO::getKey, Collectors.mapping(VO::getValue, Collectors.toList())));
System.out.println(resultMap);
}
// 假设VO类的定义如下
static class VO {
private String key;
private String value;
public VO(String key, String value) {
this.key = key;
this.value = value;
}
public String getKey() {
return key;
}
public String getValue() {
return value;
}
}
// 获取一个List<VO>的示例数据
private static List<VO> getListOfVO() {
List<VO> voList = List.of(
new VO("key1", "value1"),
new VO("key2", "value2"),
new VO("key1", "value3"),
new VO("key2", "value4")
);
return voList;
}
}
```
运行以上代码,将会输出以下结果:
```
{key1=[value1, value3], key2=[value2, value4]}
```
这里使用了`Collectors.groupingBy`方法来根据VO对象的key属性进行分组,然后使用`Collectors.mapping`方法将VO对象的value属性提取出来并转换为List<String>。最终得到的结果是一个Map,其中key是VO对象的key属性,value是对应的value属性的列表。