微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

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

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

编辑:无论我使用什么方法,我都需要能够在最后的long []数组上使用Arrays.binarySearch.

解决方法

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

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

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

另一种解决方案. (循环中没有方法调用:-)

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的实际大小.因此,如果这应该正确完成,您需要将它放在循环中,迭代直到所有字节都被读取.

原文地址:https://www.jb51.cc/java/128469.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐