Для очистки списка данных я создал метод, который принимает список данных и список операций очистки, которые необходимо выполнить.
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;
}
Проблема в том, что мы снова создаем весь список, так как он Collectors.toList()
возвращает новый список. Можем ли мы достичь того же результата без использования дополнительного пространства?
Ниже приведен код для вызова:
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()
возвращаетCollector
not, aList
и no: вы не можете иметь «лишние данные» без «лишнего пробела»