Bom padrão de design para executar um processo em uma coleção de dados?
-
19-09-2019 - |
Pergunta
Melhor explicado com código, eu acho, este é apenas um exemplo simples:
public class MyPOJO {
public String name;
public int age;
public MyPOJO(String name, int age) {
this.name = name;
this.age = age;
}
}
public class MyProcessor {
public List<MyPOJO> process(List<MyPOJO> mypojos) {
List<MyPOJO> temp = new ArrayList<MyPOJO>;
for (int i=0; i <moypojos.size(); i++) {
if (filterOne(mypojos[i])) continue;
if (filterTwo(mypojos[i])) continue;
if (filterThree(mypojos[i])) continue;
temp.add(mypojos[i];
}
}
public boolean filterOne(MyPOJO mypojo) {
// in practice filters aren't so basic
return (mypojo.age < 21);
}
// assume implementations for the other filter methods
}
Caramba, isso é feio. Basicamente, tenho uma coleção e gostaria de passar por uma espécie de peneira para continuar processando os objetos que atendem a certos critérios. Meu palpite é que existe um padrão melhor para isso do que um monte de métodos que retornam booleanos.
Solução
Você pode ter uma lista de IFilters
.
igual a
boolean filtersResult = false;
for (IFilter filter : filters) {
filterResult = filter.process(mypojos[i])
if (filterResult)
break;
}
Outras dicas
Você pode implementar seus filtros para que eles recebam uma coleção e devolva uma coleção filtrada:
public interface IFilter<E> {
public Collection<E> filter(Collection<E> input);
}
Dessa forma, você pode encadear filtros de maneira muito trivial. A desvantagem é que, para grandes coleções, é mais lenta e ocupa mais espaço; Mas o código é muito mais legível.
Por que não usar Fean-Query? Pode tornar seu código legível.
List<MyPOJO> result=selectBean(MyPOJO.class).where(
not(
anyOf(
value("aga",lessThan(21)),
value("age",greaterThan(50))
)
)
.executeFrom(myPojos).