gpt4 book ai didi

java - 在Java中从一维数组快速转换为二维

转载 作者:塔克拉玛干 更新时间:2023-11-02 18:59:39 25 4
gpt4 key购买 nike

我需要在 Java 中尽快将 long[] 转换为 long[][]。 long[] 可能不完全对应于 long[],在这种情况下,我将空行附加到 long[]。

当前代码如下所示:

private long[][] convertOneDimensionalToTwoDimensional(int numberOfRows, int rowSize, long[] srcMatrix) {
int srcMatrixLength = srcMatrix.length;
int srcPosition = 0;

long[][] returnMatrix = new long[numberOfRows][];
for (int i = 0; i < numberOfRows; i++) {
long[] row = new long[rowSize];
int nextSrcPosition = srcPosition + rowSize;
if (srcMatrixLength >= nextSrcPosition) {
// Copy the data from the file if it has been written before. Otherwise we just keep row empty.
System.arraycopy(srcMatrix, srcPosition, row, 0, rowSize);
}
returnMatrix[i] = row;
srcPosition = nextSrcPosition;
}
return returnMatrix;
}

关于如何提高效率的任何想法?比如有什么办法可以避免内存拷贝?

最佳答案

自从您使用 System.arraycopy() 以来,我认为您已经实现了最快的解决方案。在您使用数组之前,这是最快的解决方案。

但是,如果性能是一个真正的问题,并且您可以从数组切换到集合或列表,您可以更好地实现。您可以实现自己的集合,该集合使用一维数组并充当二维集合。

关于java - 在Java中从一维数组快速转换为二维,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8629202/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com