【发布时间】:2018-04-14 20:38:19
【问题描述】:
我有 Stream Stream<Integer> stream // 1,2,3,4,5,6,7,8,9
我需要从这个stream创建int[3][3]
我该怎么做?
我试过了
int[][] ints = stream
.map(i -> new int[]{i})
.toArray(int[][]::new);
但我得到:[[1], [2], [3], [4], [5], [6], [7], [8], [9]]
但我需要:[[1, 2, 3], [4, 5, 6], [7, 8, 9]]
编辑:我认为这不是重复的this,因为我需要 int[3][3] 数组而不是 String[][]
我试过这个例子
int[][] array =
IntStream.range(0, 3)
.mapToObj(x -> IntStream.range(0, 3).boxed()
.toArray(Integer[]::new))
.toArray(int[][]::new);
我得到错误
Exception in thread "main" java.lang.ArrayStoreException: [Ljava.lang.Integer;
at java.util.stream.Nodes$FixedNodeBuilder.accept(Nodes.java:1222)
at java.util.stream.IntPipeline$4$1.accept(IntPipeline.java:250)
at java.util.stream.Streams$RangeIntSpliterator.forEachRemaining(Streams.java:110)
at java.util.Spliterator$OfInt.forEachRemaining(Spliterator.java:693)
at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:481)
at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:471)
at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:545)
at java.util.stream.AbstractPipeline.evaluateToArrayNode(AbstractPipeline.java:260)
at java.util.stream.ReferencePipeline.toArray(ReferencePipeline.java:438)
at SparseMatrixSupportImpl.fromStream(SparseMatrixSupportImpl.java:25)
at SparseMatrixSupportImpl.fromStream(SparseMatrixSupportImpl.java:4)
at Main.main(Main.java:12)
编辑:
int[][] array = stream.collect(() -> new int[3][3],
(a, i) -> a[(i - 1) / 3][(i - 1) % 3] = i, (a, i) -> {
});
错误
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 3
at SparseMatrixSupportImpl.lambda$fromStream$1(SparseMatrixSupportImpl.java:28)
at java.util.stream.ReduceOps$4ReducingSink.accept(ReduceOps.java:220)
at java.util.stream.IntPipeline$4$1.accept(IntPipeline.java:250)
at java.util.Spliterators$IntArraySpliterator.forEachRemaining(Spliterators.java:1032)
at java.util.Spliterator$OfInt.forEachRemaining(Spliterator.java:693)
at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:481)
at java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:471)
at java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:708)
at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
at java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:510)
at SparseMatrixSupportImpl.fromStream(SparseMatrixSupportImpl.java:27)
at SparseMatrixSupportImpl.fromStream(SparseMatrixSupportImpl.java:4)
at Main.main(Main.java:12)
int[] values = new int[]{1, 2, 3,5,6,7,8,9,11};
Stream<Integer> integerStream = Arrays.stream(values).boxed();
【问题讨论】:
-
@AntonBalaniuc 如果 Stream 已经存在,这可能不起作用,例如来自某些来源 OP 无法更改。
标签: java arrays java-stream