一、前言
在学习了ChannelHandler和ChannelPipeline的有关细节后,接着学习Netty的EventLoop和线程模型。
二、EventLoop和线程模型
2.1. 线程模型
线程池可通过缓存和复用已有线程来提高系统性能,基本的缓冲池模式可描述如下:
· 从池中空闲链表中选取线程,然后将其分配赋予给已提交的任务。
· 当线程完成工作时,该线程又返回至空闲链表,可再进行复用。
该模式如下图所示。
池化和复用线程是针对每个任务都需要创建和销毁线程的改进,但还是需要进行上下文切换,并且随着线程数量的增加,其负担也会增加。同时,在高并发下也会出现很多线程问题。
2.2. EventLoop接口
任何网络框架的基本功能都是运行任务来处理在连接声明周期中所发生的事件,相应的编程结构通常被称为事件循环。事件循环的基本思想如下代码所示,每个任务都是一个Runnable实例。
while (!terminated) { List<Runnable> readyEvents = blockUntilEventsReady(); for (Runnable ev: readyEvents) { ev.run(); } }
延伸阅读
学习是年轻人改变自己的最好方式