从文件中读取long []的最快方法?

mem*_*com 7 java io optimization android file

我有一个包含大约200,000个长值的文件,我希望尽快将其读入long [].它适用于Android应用; 函数调用很慢(所以任何涉及用"for"循环一次读取很长时间的东西都会超级慢)我需要加载才能快速.我可以用什么?我看到的一切似乎只能快速读取字节.

我已经使用ByteBufferFileChannel从NIO包之前,这似乎是一个非常快的方式从文件加载值数组.但是,我无法弄清楚如何使用它来将数据读入long [].我已经尝试将long []包装为LongBuffer,但我无法看到任何可以将文件中的数据提供给LongBuffer的方法.

编辑:我使用哪种方法,我需要能够使用Arrays.binarySearchlong[]的高端磁盘阵列.

aio*_*obe 3

没有办法将a转换byte[]为 a long[]。但是,您可以尝试使用 aFileChannel将内容读入 a ByteBuffer,然后获取 a LongBufferthrough ByteBuffer.asLongBuffer,从中您可以获得long[]through LongBuffer.array()

您还可以尝试FileChannel.map获取MappedByteBuffer该文件的 a。这可能比通过FileChannel.read.

如果这不起作用,您可以尝试使用 aFileChannel将内容读入 a ByteBuffer,然后long使用 访问其中的 s ByteBuffer.getLong(index)


替代解决方案。(循环中没有方法调用:-)

byte[] byteArray = new byte[longCount * 8];
FileInputStream fis = new FileInputStream("lotsoflongs");
fis.read(byteArray);
fis.close();
for (int i = 0; i < longCount; i += 8)
    longArray[i >> 3] = ((long) byteArray[0+i]        << 56) +
                        ((long)(byteArray[1+i] & 255) << 48) +
                        ((long)(byteArray[2+i] & 255) << 40) +
                        ((long)(byteArray[3+i] & 255) << 32) +
                        ((long)(byteArray[4+i] & 255) << 24) +
                              ((byteArray[5+i] & 255) << 16) +
                              ((byteArray[6+i] & 255) <<  8) +
                              ((byteArray[7+i] & 255) <<  0);
Run Code Online (Sandbox Code Playgroud)

我现在已经对一些解决方案进行了基准测试,这似乎是最快的方法。另请注意,实际读入的字节数fis.read(byteArray)可能小于 byteArray 的实际大小。因此,如果应该正确完成此操作,则需要将其放入一个迭代循环中,直到读取所有字节为止。