Netty入门-ChannelHandler组件详解

本文介绍了Netty中的ChannelHandler,它是处理Channel事件的关键组件。ChannelHandler分为ChannelInboundHandler和ChannelOutboundHandler,分别用于处理入站和出站数据。ChannelInboundHandler包括channelRead方法用于读取网络数据,并提供了SimpleChannelInboundHandler简化内存释放操作。ChannelOutboundHandler则处理出站数据,允许拦截各种操作。文章还展示了ChannelHandler的生命周期方法和相关类图。
摘要由CSDN通过智能技术生成

前言

接着上篇的ByteBuf,这一篇讲讲ChannelHandler;ChannelHandler在Netty中作为处理Channel中的事件以及数据的一种方式存在,以Channel中还有ChannelPipeline,它负责编排ChannelHandler以使ChannelHandler能有效的协同作业。

Channel

Channel是NIO中的重要组件之一,它持有着远程的数据,处理连接、监听、读、写等事件操作,也就是说连接一个远程服务器、读写网络数据等等都需要Channel这个组件的参与,在Java JDK中使用NIO编程时处理Channel的事件是在Selector中进行手动的注册,每完成一个操作注册一次,然后再通过Selector进行轮询的方式获取有效的的事件对应的Channel进行处理。而在Netty中不再需要这样,Netty中的Channel同样也有事件,但Netty将其进行了包装,将将这些事件修改成了生命周期的概念;

Channel生命同期:

状态 描述
ChannelUnregistered Channel已经被创建,但还未注册到EventLoop
ChannelRegistered Channel已经被注册到EventLoop
ChannelActive Channel已经处理活动状态并可以接收与发送数据
ChannelInactive Channel没有连接到远程节点

Channel生命状态图:

image-20210719103204408

ChannelHandler

ChannelHandler是Netty框架中特有的,它是处理Channel中事件一种方式,对于入站与出站消息又分别使用ChannelInboundHandler与ChannelOutboundHandler来处理,但在之前的示例中并没有直接使用这两个类,而是使用了ChannelInboundHandlerAdapter(因为没有处理出站也就没有使用ChannelOutboundHandlerAdapter)&#x

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值