优化代码 private List<SimulationTableDto> distinct(List<SimulationTableDto> list) { // 去重 List<String> distinctList = Lists.newArrayList(); List<SimulationTableDto> distinctedColumnList = Lists.newArrayList(); for (SimulationTableDto simulationTableDto : list) { String key = simulationTableDto.getTableName() + PqlConst.VARIANT_DELIMETER + simulationTableDto.getColumn().getTitle(); if (!distinctList.contains(key)) { distinctedColumnList.add(simulationTableDto); distinctList.add(key); } } return distinctedColumnList;
时间: 2024-02-24 09:57:07 浏览: 74
C# 有关List<T>的Contains与Equals方法.doc
这段代码可以进一步优化,可以将List<String> distinctList改为Set<String> distinctSet,这样可以提高查找key是否存在的效率,因为Set是基于哈希表实现的,查找时间复杂度是O(1),而List查找时间复杂度是O(n)。另外,可以使用Java 8的Stream API来简化代码实现,如下所示:
```
private List<SimulationTableDto> distinct(List<SimulationTableDto> list) {
return list.stream()
.collect(Collectors.toMap(simulationTableDto -> simulationTableDto.getTableName() + PqlConst.VARIANT_DELIMETER + simulationTableDto.getColumn().getTitle(),
Function.identity(),
(dto1, dto2) -> dto1))
.values()
.stream()
.collect(Collectors.toList());
}
```
这样就可以用一行代码实现去重操作了。
阅读全文