增量读取大文件的最快方法

增量读取大文件的最快方法,第1张

增量读取大文件的最快方法

假设您需要一次将整个文件读入内存(就像您当前正在做的那样),那么读取较小的块和NIO都不会对您有所帮助。

实际上,您最好读取较大的块-常规IO代码会自动为您完成这些工作。

您的NIO代码目前较慢,因为您一次只能读取一个字节(使用

buffer.get();
)。

如果要分块处理(例如,在流之间传输),这是在没有NIO的情况下进行处理的标准方法:

InputStream is = ...;OutputStream os = ...;byte buffer[] = new byte[1024];int read;while((read = is.read(buffer)) != -1){    os.write(buffer, 0, read);}

这仅使用1 KB的缓冲区大小,但可以传输无限量的数据。

(如果您在功能级别上扩展了您实际想要做什么的详细信息,我可以进一步改善它以得到更好的答案。)



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5499932.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-13
下一篇 2022-12-12

发表评论

登录后才能评论

评论列表(0条)

保存