我正在使用这段代码将一个Set转换为一个List:

Map<String, List<String>> mainMap = new HashMap<>();

for (int i=0; i < something.size(); i++) {
  Set<String> set = getSet(...); //returns different result each time
  List<String> listOfNames = new ArrayList<>(set);
  mainMap.put(differentKeyName, listOfNames);
}

我希望避免在循环的每次迭代中创建一个新列表。这可能吗?


当前回答

最近我发现了这个:

ArrayList<T> yourList = Collections.list(Collections.enumeration(yourSet<T>));

其他回答

Java 8提供了使用流的选项,你可以从Set<String> setString中获得一个列表为:

List<String> stringList = setString.stream().collect(Collectors.toList());

尽管内部实现现在提供了一个ArrayList实例:

public static <T>
    Collector<T, ?, List<T>> toList() {
        return new CollectorImpl<>((Supplier<List<T>>) ArrayList::new, List::add,
                                   (left, right) -> { left.addAll(right); return left; },
                                   CH_ID);
    }

但是JDK并不能保证它。如本文所述:

没有对类型、可变性、可序列化性或 返回List的线程安全;如果更多的控制返回 需要清单,使用收集(供应商)。

如果你想确保总是,那么你可以请求一个实例,具体为:

List<String> stringArrayList = setString.stream()
                     .collect(Collectors.toCollection(ArrayList::new));

我发现这工作很好,有用的从一个集合创建一个列表。

ArrayList < String > L1 = new ArrayList < String > ();
L1.addAll(ActualMap.keySet());
for (String x: L1) {
    System.out.println(x.toString());
}

我会这样做:

Map<String, Collection> mainMap = new HashMap<String, Collection>();

for(int i=0; i<something.size(); i++){
  Set set = getSet(...); //return different result each time
  mainMap.put(differentKeyName,set);
}

最简单的解决方案

我想要一种非常快速的方法将我的set转换为List并返回它,所以在一行中我做到了

 return new ArrayList<Long>(mySetVariable);

由于到目前为止还没有提到它,从Java 10开始,你可以使用新的copyOf工厂方法:

List.copyOf(set);

来自Javadoc:

按迭代顺序返回一个不可修改的List,其中包含给定Collection的元素。

注意,这将在底层创建一个新的列表(确切地说是ImmutableCollections$ListN)

在给定集合上调用Collection#toArray(),然后 将这些对象放入一个新数组中。