繁体   English   中英

FileUtils.readFileToByteArray与Files.readAllBytes

[英]FileUtils.readFileToByteArray vs Files.readAllBytes

当我使用java 7中的Files.readAllBytes时遇到了以下异常,然后通过使用Apache中的FileUtils.readFileToByteArray解决了。 我通过在stackoverflow中进行一些回答来做出这个决定。 我尝试通过遍历代码来理解,以了解可以解决此问题的主要区别,但徒劳无功。 我只想知道这两种方法解决了此异常的区别。

  java.lang.OutOfMemoryError: Direct buffer memory
    at java.nio.Bits.reserveMemory(Bits.java:658)
    at java.nio.DirectByteBuffer.<init>(DirectByteBuffer.java:123)
    at java.nio.ByteBuffer.allocateDirect(ByteBuffer.java:306)
    at sun.nio.ch.Util.getTemporaryDirectBuffer(Util.java:174)
    at sun.nio.ch.IOUtil.read(IOUtil.java:196)
    at sun.nio.ch.FileChannelImpl.read(FileChannelImpl.java:143)
    at sun.nio.ch.ChannelInputStream.read(ChannelInputStream.java:65)
    at sun.nio.ch.ChannelInputStream.read(ChannelInputStream.java:109)
    at sun.nio.ch.ChannelInputStream.read(ChannelInputStream.java:103)
    at java.nio.file.Files.read(Files.java:2903)
    at java.nio.file.Files.readAllBytes(Files.java:2953)

好了,您可以使用此命令来增加缓冲区大小。 它可以解决您的错误。

-XX:MaxDirectMemorySize=256M


我试图粗略地阅读这两个源代码,发现的区别是apache方法不是尝试读取所有文件并将其存储到内存中,而是先写入输出(这是他们自己的ByteArrayOutputStream的实现)这是一个ArrayList (因此,可以说它们使用了通过-Xmx增加的内存空间)。 另一个只是将所有内容存储到一个内存空间中,这可能是您出错的原因。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM