java – 从文件中读取long []的最快方法?
我有一个包含大约200,000个长值的文件,我希望尽快将其读入long [].它适用于
Android应用;函数调用很慢(所以任何涉及用“for”循环一次读取很长的东西都会超级慢)我需要加载才能快速.我可以用什么?我看到的所有内容似乎都只能快速读取字节.
我之前使用过NIO包中的ByteBuffer和FileChannel,这似乎是一种从文件加载值数组的快速方法.但是,我无法弄清楚如何使用它将数据读入long [].我已经尝试将long []包装为LongBuffer,但是我无法看到任何可以将文件中的数据提供给LongBuffer的方法. 编辑:无论我使用什么方法,我都需要能够在最后的long []数组上使用Arrays.binarySearch. 解决方法
没有办法将byte []转换为long [].但是,您可以尝试使用
FileChannel 将内容读入
ByteBuffer ,然后获取
LongBuffer 到
ByteBuffer.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的实际大小.因此,如果这应该正确完成,您需要将它放在循环中,迭代直到所有字节都被读取. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |