我正在使用ChannelInboundHandlerAdapter类和writeAndFlush来自channelRead()的每条消息;
public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
ByteBuf msgBuffer = (ByteBuf)msg;
BinaryWebSocketFrame frame= new BinaryWebSocketFrame(msgBuffer);
ctx.writeAndFlush(frame);
}
在这种情况下:Netty是否会发布" frame"和" msg"。我知道它们是引用计数对象,因此当我尝试手动释放它们时,如下所示:
public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
ByteBuf buf = (ByteBuf)msg;
BinaryWebSocketFrame frame= new BinaryWebSocketFrame(buf);
ctx.writeAndFlush(frame);
buf.release();
frame.release();
}
但在这种情况下,我得到refCounted对象释放错误,如下所示:
io.netty.util.IllegalReferenceCountException: refCnt: 0, decrement: 1
起初,我依赖于netty它会释放相关的实例,但它偶尔会在运行时给我内存泄漏错误。
如何在这种情况下减少内存使用量,因为在每个channelRead事件中创建新实例时,如果无法正确释放它们,这不是一个好主意。
答案 0 :(得分:2)
是的,如果你打电话给writeAndFlush(...)
,你基本上是转移缓冲区的所有权。如果写入缓冲区或写入失败,Netty本身将释放缓冲区。