<p>BufferOverflowException 是 ByteBuffer 写入超限异常,非 JVM 内存溢出;它在 put() 超过 remaining()(即 limit - position)时立即抛出,与 capacity 无关,常见于未检查剩余空间、忘记 flip/compact 或直接分配过小缓冲区。</p>

详解Java中的BufferOverflowException_NIO缓冲区写入超出的预防

BufferOverflowException 是写进 ByteBuffer 时超限,不是内存溢出

这个异常和 JVM 堆内存溢出(OutOfMemoryError)完全无关,它只发生在 NIO 的 ByteBuffer 写入操作中——当你试图往一个已满的缓冲区继续 put(),或者 put() 超过剩余空间(remaining()),就会立刻抛出 BufferOverflowException

常见错误现象:

写入前必须检查 remaining(),不能只看 capacity()

capacity() 是缓冲区总大小,limit() 是当前可写/可读边界,position() 是下一次操作位置——真正决定还能写多少的是 remaining() == limit() - position()。很多同学误以为“只要没超 capacity 就安全”,结果在 flip()position 回到 0、limit 缩到之前写入长度,此时 remaining() 可能只剩 0。

实操建议:

避免手动管理 positionlimit:用 flip() / compact() / clear() 的真实含义

这三个方法不是“清空数据”,而是重置元数据指针,误用会直接导致 BufferOverflowException 或数据覆盖:

典型坑:flip() 后没 compact() 就再次 put(),此时 position == limitremaining() 为 0,必然抛异常。

大块数据写入必须分片,别指望单个 ByteBuffer 吃下全部

NIO 缓冲区不是动态扩容容器。即使你用 allocate(1024 * 1024) 分配了 1MB,遇到 5MB 数据也得自己拆。不拆的后果不是慢,是直接崩在第一个 put()

实操建议:

容易被忽略的一点:ByteBuffer.array() 返回的底层数组长度恒等于 capacity(),但 arrayOffset()limit() 才决定有效范围;直接拿 array() 当普通数组用,可能读到脏数据或越界。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。