手动释放对象

This commit is contained in:
Guoqs
2024-12-28 11:36:35 +08:00
parent 2ff36a6ed7
commit 458c216a6d

View File

@@ -8,6 +8,7 @@ import com.jsowell.netty.service.electricbicycles.EBikeBusinessService;
import io.netty.buffer.ByteBuf; import io.netty.buffer.ByteBuf;
import io.netty.channel.*; import io.netty.channel.*;
import io.netty.handler.timeout.ReadTimeoutException; import io.netty.handler.timeout.ReadTimeoutException;
import io.netty.util.ReferenceCountUtil;
import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
@@ -60,25 +61,30 @@ public class ElectricBicyclesServerHandler extends ChannelInboundHandlerAdapter
*/ */
@Override @Override
public void channelRead(ChannelHandlerContext ctx, Object message) throws Exception { public void channelRead(ChannelHandlerContext ctx, Object message) throws Exception {
byte[] msg = (byte[]) message; try {
// 处理数据 byte[] msg = (byte[]) message;
byte[] response = eBikeService.process(msg, ctx); // 处理数据
if (Objects.nonNull(response)) { byte[] response = eBikeService.process(msg, ctx);
log.info("[电单车===>响应数据]:{}", BytesUtil.binary(response, 16)); if (Objects.nonNull(response)) {
// 响应客户端 log.info("[电单车===>响应数据]:{}", BytesUtil.binary(response, 16));
ByteBuf buffer = ctx.alloc().buffer().writeBytes(response); // 响应客户端
// this.channelWrite(channel.id(), buffer); ByteBuf buffer = ctx.alloc().buffer().writeBytes(response);
ctx.writeAndFlush(buffer); // this.channelWrite(channel.id(), buffer);
// if (!CollectionUtils.containsAny(notPrintFrameTypeList, frameType)) { ctx.writeAndFlush(buffer);
// // 应答帧类型 // if (!CollectionUtils.containsAny(notPrintFrameTypeList, frameType)) {
// byte[] responseFrameTypeBytes = YKCFrameTypeCode.PlatformAnswersRelation.getResponseFrameTypeBytes(frameTypeBytes); // // 应答帧类型
// String responseFrameType = YKCUtils.frameType2Str(responseFrameTypeBytes); // byte[] responseFrameTypeBytes = YKCFrameTypeCode.PlatformAnswersRelation.getResponseFrameTypeBytes(frameTypeBytes);
// log.info("【>>>>>平台响应消息>>>>>】channel:{}, 响应帧类型:{}, 响应帧名称:{}, 原帧类型:{}, 原帧名称:{}, 序列号域:{}, response:{}", // String responseFrameType = YKCUtils.frameType2Str(responseFrameTypeBytes);
// channel.id(), responseFrameType, YKCFrameTypeCode.getFrameTypeStr(responseFrameType), // log.info("【>>>>>平台响应消息>>>>>】channel:{}, 响应帧类型:{}, 响应帧名称:{}, 原帧类型:{}, 原帧名称:{}, 序列号域:{}, response:{}",
// frameType, YKCFrameTypeCode.getFrameTypeStr(frameType), serialNumber, // channel.id(), responseFrameType, YKCFrameTypeCode.getFrameTypeStr(responseFrameType),
// BytesUtil.binary(response, 16)); // frameType, YKCFrameTypeCode.getFrameTypeStr(frameType), serialNumber,
// } // BytesUtil.binary(response, 16));
// }
}
} finally {
ReferenceCountUtil.release(message);
} }
} }
/** /**