Как избежать ленивого применения List.transform в guava?

Map<String,Object> map = Maps.newHashMap();
map.put("test","123");
map.put("fuyou001","456");
map.put("id",145);
List<Map<String,Object>> list = Lists.newArrayList();
list.add(map);
Lists.transform(list, new Function<Map<String, Object>, Object>() {
  @Override
  public Object apply(@Nullable Map<String, Object> input) {
    System.out.println("test:" + input);
    return input;
  }
});
System.out.println(list);`

Консоль не отображает "test..."

Как избежать ленивого применения Я также стараюсь

List<Map<String,Object>> newList = new ArrayList<Map<String, Object>>(list.size());
Collections.copy(newList,list);

но не эффект

Ответ 1

Function вообще не должно иметь побочных эффектов; что ваша настоящая проблема.

Тем не менее, если вы настаиваете на немедленном применении преобразования, выполните копию: Lists.newArrayList(Lists.transform(list, function)).

Ответ 2

Использование ImmutableList заставит значения вычисляться с нетерпением, и, следовательно, впоследствии не потребуется дополнительная копия. Это, пожалуй, более элегантное решение:

list = ImmutableList.copyOf(Lists.transform(list, 
  new Function<Map<String, Object>, Object>() {
  @Override
  public Object apply(@Nullable Map<String, Object> input) {
    System.out.println("test:" + input);
    return input;
  }
}));
System.out.println(list);`

Ответ 3

Чтобы дополнить ответ Луи, вы используете Lists.transform(), как если бы он модифицировал оригинальный list, например Collections.sort(). Это не так.

Вы должны использовать возвращаемое значение Lists.transform(), чтобы увидеть что-то, имея в виду, что это представление, которое оценивается каждый раз, когда вы его вызываете. Поэтому, если вам нужно использовать результат несколько раз, как сказал Луис, сделайте копию в новом list (ArrayList, ImmutableList и т.д.).