По сути, вы создаете интерфейс Function:
public interface Func<In, Out> {
public Out apply(In in);
}
и затем передайте анонимный подкласс вашему методу.
Ваш метод может применить функцию к каждому элементу на месте:
public static <T> void applyToListInPlace(List<T> list, Func<T, T> f) {
ListIterator<T> itr = list.listIterator();
while (itr.hasNext()) {
T output = f.apply(itr.next());
itr.set(output);
}
}
// ...
List<String> myList = ...;
applyToListInPlace(myList, new Func<String, String>() {
public String apply(String in) {
return in.toLowerCase();
}
});
или создайте новый List
(в основном, создавая отображение из списка ввода в список вывода):
public static <In, Out> List<Out> map(List<In> in, Func<In, Out> f) {
List<Out> out = new ArrayList<Out>(in.size());
for (In inObj : in) {
out.add(f.apply(inObj));
}
return out;
}
// ...
List<String> myList = ...;
List<String> lowerCased = map(myList, new Func<String, String>() {
public String apply(String in) {
return in.toLowerCase();
}
});
Какой из них предпочтительнее, зависит от вашего варианта использования. Если ваш список очень большой, решение на месте может быть единственным жизнеспособным; если вы хотите применить много разных функций к одному и тому же исходному списку для создания множества производных списков, вам понадобится версия map
.