昨天只看到EventLoop了。还有一种MultithreadEventLoopGroup,
实际上他们实现的接口都是EventExecutorGroup和EventLoopGroup
看看抽象类 MultithreadEventExecutorGroup:
实际上她就是一个EventExecutor池。所以她还是提供EventExecutor的。
而且这里的EventExecutor的实现就是SingleThreadEventLoop,然后多线程的果然是多。他的操作都无非是批量操作。请看他的next函数
@Override
public EventExecutor next() {
return children[Math.abs(childIndex.getAndIncrement() % children.length)];
}
这里的childIndex是一个ActomicInteger, 而children正是EventExecutor的数组
这里的抽象类,又一个空着了,那就是函数
@Override
protected EventExecutor newChild(int nThreads, ThreadFactory threadFactory, final SelectorProvider selectorProvider);
这个方法是生成EventExecutor池是使用的。我们来看看具体的实现,比如
NioEventLoopGroup中的实现
@Override
protected EventExecutor newChild(
ThreadFactory threadFactory, ChannelTaskScheduler scheduler, Object... args) throws Exception {
SelectorProvider selectorProvider;
if (args == null || args.length == 0 || args[0] == null) {
selectorProvider = SelectorProvider.provider();
} else {
selectorProvider = (SelectorProvider) args[0];
}
return new NioEventLoop(this, threadFactory, scheduler, selectorProvider);
}
原来这还是从NioEventLoop啊。所以,MultithreadEventEventLoopGroup就是多处理几个EventLoop,并且是同步的,注意next方式。
分享到:
相关推荐
Netty4.0全部jar包.开发时候只需要倒入总的哪一个netty4.0.jar就行了 后缀为resources.jar的全部是源码。 简单的代码例子在netty-example-resources.jar里面。
Netty (netty-netty-4.0.56.Final.tar.gz)是一个 NIO 客户端服务器框架,可以快速轻松地开发协议服务器和客户端等网络应用程序。它极大地简化和流线了网络编程,例如 TCP 和 UDP 套接字服务器。 “快速和简单”并...
描述文档请看我的个人博客:www.mesoftware.cn
NIO socket开发,netty4.0工具包。
Springboot2.0.8集成 netty4 ,使用protobuf作为ping的数据交换,比json更加的小巧,占用数据量更小,可用于任何第三方应用做心跳监控。 已完成功能: - 客户端授权验证(基于protoBuff) - 心跳检测(基于protoBuff) ...
netty4.0 关于buffe
NULL 博文链接:https://bijian1013.iteye.com/blog/2340636
Netty4.0实现http服务,客户端通过http请求,服务器进行业务处理,返回响应,交互采用json格式
netty4.0.45jar包socket和http工具包,公司最近开发一个保险项目,用到socket,经过公司10个以上项目验证,该版本的netty4.0.45相当稳定,可以在生产环境上使用。
Netty4.0.54英文版API文档,与官网中文档内容一致,方便用户在离线环境下,开发Netty
Netty是由JBOSS提供的一个java开源框架。Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序dsf。...netty, 4.0.28, Final, jar包, 含源码
包含javadoc,jar 两个文件夹。 doc中是文档资料。 jar是源码及常用例子,均好源码,好使。
netty4.0 各种应用类型的demo源码 比较全
Netty project - an event-driven asynchronous network application framework http://netty.io/
Netty官方4.0.42版jar包
netty 4.0版本
Netty是一个异步事件驱动的网络应用程序框架,主要用于快速开发可维护的高性能协议服务器和客户端。它基于Java NIO进行设计,因此提供了高层次的抽象和简化的API,使得开发者可以更加方便地构建网络应用。 Netty在...
多种数据访Netty自带的拆包解包,异常检测等机制让你从NIO的繁重细节中脱离出来,让你只需要关心业务逻辑 Netty解决了JDK的很多包括空轮询在内的bug Netty底层对线程,selector做了很多细小的优化,精心设计的...
NULL 博文链接:https://bijian1013.iteye.com/blog/2340639
NULL 博文链接:https://bijian1013.iteye.com/blog/2340632