Estou tentando filtrar um recurso e excluir alguns elementos com base em um campo. Para excluir, tenho um conjunto (que contém um ID que precisa ser excluído) e uma lista (contém vários intervalos de IDs que precisam ser excluídos). Eu escrevi a lógica abaixo e não estou satisfeito com a segunda lógica do filtro. Existe alguma maneira melhor de fazê-lo com o Java 8? Eu preciso fazer o mesmo para incluir intervalos também.
Set<String> extensionsToExclude = new HashSet<>(Arrays.asList("20","25","60","900"));
List<String> rangesToExclude = new ArrayList<>(Arrays.asList("1-10","20-25","50-70","1000-1000000"));
return directoryRecords.stream()
.filter((directoryRecord) -> !extensionsToExclude.contains(directoryRecord.getExtensionNumber()))
.filter((directoryRecord -> {
Boolean include = true;
for(String s : rangesToExclude) {
String [] rangeArray = s.split("-");
Integer extension = Integer.parseInt(directoryRecord.getExtensionNumber());
if(extension <= Integer.parseInt(rangeArray[0]) && extension >= Integer.parseInt(rangeArray[1])) {
include = false;
}
}
return include;
}))
.collect(Collectors.toList());
Obrigado :)
Booleanobjetos quando você só precisa de umbooleanvalor. Embora aqui, a variávelincludeseja totalmente obsoleta. Quando a única alteração possível é detrueparafalse, você pode substituirinclude = false;por,return false;pois o resultado final já foi determinado. Em seguida, oreturn include;no final pode ser substituídoreturn true;e a declaração da variável removida. E comodirectoryRecordnunca muda no loop, você pode mover oInteger extension = Integer.parseInt(directoryRecord.getExtensionNumber());antes do loop (e mudarIntegerparaint).