`

netty学习之ChannelConfig

阅读更多

         今天我来来看一下整个ChannelConfig的类的继承层次:



 

        整个类结构来说还是比较好理解的,我就将作者的意图分析一下:

        整个ChannelConfig的类的继承层次我感觉是非常明了的:

首先在顶层的ChannelConfig,这个里面定义一个Channel可以设置的基本参数,一堆的options,还有相应的bufferFactory和pipelineFactory,以及connectTimeoutMillis参数,这里就不多讲了。

        接下来有一个默认的ChannelConfig的实现,叫DefaultChannelConfig,在这个里面提供了默认的bufferFactory和connectTimeoutMillis的实现。

        下面的SocketChannelConfig接口提供了设置socket的一些基本参数,比如tcpNoDelay、sendBufferSize等参数。

         DefaultSocketChannelConfig类里面在构造函数的时候需要一个socket,然后在设置属性的时候直接将该属性设置到socket上面,这个类实现了SocketChannelConfig接口,同时也继承DefaultChannelConfig类,感觉bio下面直接使用这个就ok了。

        然后针对nio的情况,作者又派生了一个NioSocketChannelConfig接口,这个里面有一些参数

"writeBufferHighWaterMark" "writeBufferLowWaterMark" "writeSpinCount" "receiveBufferSizePredictor" "receiveBufferSizePredictorFactory" 以及相应的get/set方法,这个是nio属性设置的重点,打算单独讲解。

        处在这个上面最底层的是DefaultNioSocketChannelConfig,这个类实现DefaultSocketChannelConfig,以及NioSocketChannelConfig这个接口,这个在以后详细讲解。

      关于UDP的diagram的就不详细讲解了,都差不多。

 

  • 大小: 61.8 KB
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics