Do czyszczenia listy danych stworzyłem metodę, która akceptuje listę danych i listę operacji czyszczenia do wykonania.
public <T> List<T> cleanData(List<T> data, List<Function<T, T>> cleanOps) {
List<T>dataNew=data.stream().map((str) -> {
T cleanData = str;
for(Function<T,T> function:cleanOps) {
cleanData=function.apply(cleanData);
}
return cleanData;
}).collect(Collectors.toList());
return dataNew;
}
Problem polega na tym, że ponownie tworzymy całą listę, ponieważ Collectors.toList()
zwraca nową listę. Czy możemy osiągnąć ten sam wynik bez korzystania z dodatkowej przestrzeni?
Poniżej znajduje się kod wywołania:
public void processData() {
List<Function<String, String>> cleanOps = new ArrayList<>();
cleanOps.add(String::toLowerCase);
cleanOps.add(str -> str.replaceAll(" ", ""));
List<String> data = new ArrayList<>();
data.add("John Doe");
data.add("Jane Doe");
System.out.println(Arrays.toString(cleanData(data, cleanOps).toArray()));
}
toList()
zwraca aCollector
nieList
i nie: nie możesz mieć „dodatkowych danych” bez „dodatkowej przestrzeni”