作者:mobiledu2502896593 | 来源:互联网 | 2023-09-16 19:07
最近刚开始接触netty,百度了一个netty框架demo。正常运行没问题,在加入心跳检测newIdleStateHandler();在这里插入代码片@Overrideprotec
最近刚开始接触netty,百度了一个netty框架demo。正常运行没问题,在加入心跳检测new IdleStateHandler();在这里插入代码片 @Override protected void initChannel(SocketChannel socketChannel) throws Exception { //EchoServerHandler被标注为@shareable,所以我们可以总是使用同样的案例 // socketChannel.pipeline().addLast(serverHandler);这是最先demo里的处理消息的地方 socketChannel.pipeline().addLast(new IdleStateHandler(5, 0, 0, TimeUnit.SECONDS)); socketChannel.pipeline().addLast(new StringDecoder()); socketChannel.pipeline().addLast(heartHandler);//这是后面加了处理心跳检测的地方 }
这个时候在重写channelRead(ChannelHandlerContext ctx, Object msg)时,接收到msg,对msg进行转换ByteBuf类型时,提示msg是string类型,不能转换。
但是在前面demo的时候获取到的msg是ByteBuf,无异常。如下图
心理想着我们重写方法前,msg的类型已经不同了,那么这一块的问题肯定没有。后面又回到在进行通道加载的时候,是否有什么异常?如下:
然后通过调换通道的addLast顺序,发现问题解决了,不再报类型转换异常。就怀疑是通道的加载顺序不一致。更深层次的原因还没找到。如有知道的大神,欢迎指教!