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

时间:2010-09-29 16:39:35

标签: java android file optimization io

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

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

编辑:无论我使用哪种方法,我都需要能够在Arrays.binarySearch数组末尾使用long[]

2 个答案:

答案 0 :(得分:3)

无法将<{1}} 投射到byte[]。但是,您可以尝试使用FileChannel将内容读入ByteBuffer,然后抓住LongBufferByteBuffer.asLongBuffer,您可以从long[]获得long[]通过LongBuffer.array()

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

如果这不起作用,您可以尝试使用FileChannel将内容读入ByteBuffer,然后使用long访问其中的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);

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

答案 1 :(得分:1)

尝试使用DataInputStream。由于您可以轻松找到文件的长度,因此您还知道它包含多少元素(文件大小/ 8字节)。

 DataInputStream dataStream = new DataInputStream(inputStream);

 long count = filesize/8;
 long[] longArray = new long[count];

 for(int i=0;i<count;i++) 
     longArray[i] = dataStream.getLong();

猜猜这应该足以让你有个主意。