【问题标题】:How to avoid applied lazily Lists.transform in guava?如何避免在番石榴中懒惰地应用 Lists.transform?
【发布时间】:2012-11-17 09:41:21
【问题描述】:
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);

但不影响

【问题讨论】:

    标签: java guava


    【解决方案1】:

    Functions 一般不应该有副作用;这才是你真正的问题。

    也就是说,如果您坚持立即应用转换,请复制:Lists.newArrayList(Lists.transform(list, 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】:

      为了补充 Louis 的答案,您使用 Lists.transform() 就好像它修改了原始的 list,例如 Collections.sort()。没有。

      您必须使用Lists.transform() 的返回值来查看发生的情况,记住它是一个视图,每次调用它时都会对其进行评估。因此,如果您需要多次使用结果,如 Louis 所说,请在新的 ListArrayListImmutableList 等)中复制一份。

      【讨论】:

        猜你喜欢
        • 2014-11-11
        • 2013-01-16
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2012-06-04
        • 1970-01-01
        • 2015-04-29
        相关资源
        最近更新 更多