簡體   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