在Java中,是否有一种单行的方法来创建使用对象的n个克隆来初始化的集合?
我想要相当于这样的:
foo = vector<vector<int> >(10); c++,创建10个不同的空向量。[ [] for i in range(10) ],一个由10个不同的空数组组成的数组Array.new(10) { [] } Ruby与Python相同在Java里,我发现
new ArrayList<ArrayList<Integer> >(Collections.nCopies(10, new ArrayList<Integer>()))但是,这并不等同于其他示例,因为列表别名。
是否有一种方法可以创建一个由不同对象克隆组成的数组,而不使用for循环,最好不使用外部图书馆
发布于 2014-11-10 22:16:20
如果您使用Java 8,您可以使用它的流:
Stream.generate(ArrayList<Integer>::new)
.limit(10).collect(Collectors.toList());Stream.generate()方法使用一个知道如何生成值的Supplier,并生成这些值的无限流(每个值都是通过再次调用供应者获得的,因此它们都是不同的,与Collections.nCopies()不同)。在流中放置一个limit(),然后将结果收集到一个列表中,从而生成一个不同条目的列表。
请注意,从Java16开始,Stream有一个toList()方法,因此它可以变得更清晰一些:
Stream.generate(ArrayList<Integer>::new).limit(10).toList();发布于 2017-05-24 22:50:47
对于那些想传递构造函数参数的人,(这在接受答案和供应商中是不可能的,就像提到的这里那样)--您可以使用以下方法(我不知道是否有更好的解决方案,但至少满足了我的需要):
final List<MyObject> result = IntStream.range(0, n)
.mapToObj(index -> new MyObject(...))
.collect(Collectors.toList());然而,您可以将n替换为您希望填充列表的元素数,而MyObject和new MyObject(...)则分别替换为您的类型和ctor-调用。
这将创建一个从0到n (n排他)的整数流,将每个“索引”映射到lambda-expr返回的任何对象。在mapToObj中,并最终将流转换为一个列表,该列表将包含n不同的MyObject实例。
发布于 2014-11-10 23:02:15
即使引入了Java8 Supplier,不幸的是,也没有像nCopies这样简洁的一行程序。老实说,我不知道为什么。(不过@DavidConrad已经证明了Stream可以做到这一点。)
您可以轻松地自己创建一个,例如:
public static <E, L extends List<? super E>> L fill(
L list, Supplier<E> sup, int n) {
for(; n > 0; --n)
list.add(sup.get());
return list;
}打电话给:
List<List<Integer>> list = ArrayUtils.fill(
new ArrayList<>, ArrayList<Integer>::new, 10
);对于数组,有一个新的方法Arrays#setAll
Integer[] oneToTen = new Integer[10];
Arrays.setAll(oneToTen, i -> i + 1);
List<Integer> asList = Arrays.asList(oneToTen);但是它是一个void方法,所以它不能在一个语句中使用。(个人评论:为什么Java不能流动?)
在Java 8之前,没有一个库方法可以这样做,创建一个库更麻烦。由于clone是受保护的,所以不能一般地调用它。反射是可以做到的,但是反射是相当麻烦的。
https://stackoverflow.com/questions/26853851
复制相似问题