吃透Netty源码系列五十五之NioEventLoopGroup创建细节一
一行代码的秘密
我们今天就来看看一行代码里面的细节,涉及很多东西,有很多开始不会关心的一些问题。
EventLoopGroup bossGroup = new NioEventLoopGroup(1);
NioEventLoopGroup的terminationFuture终止回调
在初始化后面会给每个终止回调添加一个相同的终止回调,只有所有的子事件循环NioEventLoop
终止了才会回调事件循环组NioEventLoopGroup
的成功终止。
NioEventLoop的初始化
io.netty.noKeySetOptimization
是否禁用选择器的selectedKeys
优化,默认是不禁用,也就是要优化,至于怎么优化,后面会说,其实就是用反射改变了选择器的selectedKeys
和publicSelectedKeys
的属性,变成了SelectedSelectionKeySet
类型,因为原生的底层是HashMap
实现的,而优化的是数组实现的,提高效率。
io.netty.selectorAutoRebuildThreshold
这个表示NIO
的空轮序多少次后重建选择器,也就是解决NIO
的空轮询BUG
的参数。
NioEventLoop构造方法的newTaskQueue
PlatformDependent
其实我想说的是这个类的初始化。
MAX_DIRECT_MEMORY_SIZE_ARG_PATTERN
这个是用来解析虚拟机设置参数的,后面会说,最大堆外内存的设置可以根据这个来设置。
平台相关属性
这里可以获取操作系统和虚拟机信息。
CAN_ENABLE_TCP_NODELAY_BY_DEFAULT
设置TCP是否禁止Nagal
算法,其实就是看是否是安卓,不是安卓就禁止,不开启的话可能会有延迟的,可能你发送的数据太小,不会马上发送,要积压一会儿到了阈值才会发送,貌似好像小数据延迟200ms
后也会发送,一般都会开启,为了低延迟。
PlatformDependent0的初始化
io.netty.noUnsafe是否禁用unsafe
如果禁用了会抛异常。
PlatformDependent0的isAndroid0
其实就是获取系统属性比较字符串:
io.netty.tryReflectionSetAccessible启用反射访问
默认java9
以下的是可以启用,所以9
以及以上就要设置啦,不然后面不会使用NoCleaner
的缓冲区,这个貌似在以前的文章有讲过。
获取unsafe
可以看到要启用io.netty.noUnsafe
才能去用反射获取unsafe
属性。而这里申请了一个1字节的直接缓冲区也是为了后面的反射。
获取直接缓冲区的address属性
获取DirectByteBuffer的无清除器的构造方法
这个构造方法就是没有清除器cleaner
的,而是直接用unsafe
去释放。
获取address属性和字节数组的内存偏移
可以方便直接操作内存数据。
继续PlatformDependent属性
获取最大直接缓冲区大小
如果你的VM
参数设置了,那就会在这里被正则取出来,然后处理。
否则就是调用运行时最大可分配内存,其实是虚拟机尝试获得的最大内存,应该是堆内的,这里堆外也设置成这个值了:
看看LOG
,居然分了4G
,我电脑还有9G
内存可分配:
静态代码块
设置使用没有清理器的直接缓冲区
设置清理器
当然你如果强行要设置有清理器的,那也可以,他也会给你初始化好清理器,安卓当然是没有的。
分为两个版本,具体区别可以看这篇文章。
优先使用直接缓冲区
默认就优先使用直接缓冲区。
有点长了,后面的下次再说吧。
好了,今天就到这里了,希望对学习理解有帮助,大神看见勿喷,仅为自己的学习理解,能力有限,请多包涵。