学习Netty准备-NIO(Buffer\Channel\Selector)

JDK提供NIO相关的类,其中比较主要的三个Buffer、Channel、Selector核心部分。

Buffer是缓冲区,提供输入输出暂存区域。在没有Buffer之前我们都是通过直接read获取到字节数据,返回的是字节数组,在进行各种获取、设置、转换、复制、压缩等操作的时候都需要自己去实现复杂的逻辑,因此后面提出了缓冲区的概念,其本质还是一个字节数组,只不过提供了大量的API方法,供开发者调用。

下面先看一下相关类图,如图1-1,其中JDK提供了各种类型的Buffer,byte、int、float、double、long等基本类型的Buffer,大体会分为堆内分配空间和直接内存分配空间,还有只读的实现。后面也列出了两个类ByteOrder(BIG_ENDIAN、LITTLE_ENDIAN)和Bits,ByteOrder标识大端和小端,Bits则提供各种类型直接互相的转换工具类。


图1-1

下面重点分析一下ByteBuffer,其中比较重要的参数,具体的逻辑关系如图1-2

容量(Capacity):缓冲区大小;

上限(Limit):缓冲区可用边界,越过上界的区域不可读写;

位置(Position):下一个读写的索引,随着读写递增;

标记(Mark):Mark一个位置,可以在之后设置位置为标记值再次读写。


图1-2

下面看一下提供的API方法:

Buffer接口中主要是提供以上四个参数相关的操作方法,例如capacity()返回容量,position()返回当前位置,position(int )设置新的位置信息,flip()读写模式转换(针对于position  limit的数字切换),mark()\reset()标记位置设置、重置,truncate()清空缓冲区,注意这里面所有的操作都是针对于四个重要参数的相关操作。

图1-3

再看一下ByteBuffer具体实现里面提供的方法如图1-3,allocate()\allocateDirect()初始化一个堆内的缓冲区或者直接内存缓冲区,wrap()提供字节数组的复制功能,slice()、duplicate()提供字节缓冲区截取、复制的功能,get()\put()方法提供相关的设置、获取具体信息的方法,同时提供针对于各种基本类型put、get的方法,会屏蔽类型所占类型的长度,进行直接的读取,屏蔽实现细节。(其中NIO也实现自己的ByteBuf,后面会去对比)

图1-3

Channel是NIO的第二个重要的组成部分,它是在Buffer(字节缓冲区)和文件或者网络套接字之间传输数据,所有的操作都是在Buffer的基础上面进行,read\write都是跟ByteBuffer打交道。同时对比BIO的InputStream和OutputStream在于channel是一个双向读写的,而stream只可以单方向。这一部分主要分析serverSocket相关的channel.如图:2-1


图2-1

从类图上面分析可以看到socketChannel实现了可读写的ByteChannel、聚集分散读写的ByteChannel,其实就是实现了read(ByteBuffer)、write(ByteBuffer)、read(ByteBuffer,int,int)(分散读,读取某一段,不顺序读写)、write(ByteBuffer[],int,int)。

同时实现了NetWorkChannel实现网络地址的绑定,SelectableChannel提供多路复用的实现,后面会详细介绍,InterruptiableChannel提供可阻断的的方法。

下面通过获取channel、配置非阻塞来简单说明一下具体的过程。(如图2-2)

ServerSocketChannel.open();

ServerSocketChannel.configureBlocking(false);


图2-2

Selector是Java NIO中能够检测一到多个NIO通道,并能够检查通道是否为诸如读写事件做好准备的组件。这样,一个单独的线程可以管理多个channel,从而管理多个网络连接。

操作系统的一个重要功能是处理IO请求并通知各个线程它们的数据准备就绪了,Selector的就绪选择的处理是委托到具体的操作系统上的,选择器类提供了这种抽象,使得Java代码能以可移植的方式,请求底层的操作系统提供就绪选择服务。

基本而言,选择器是对select,poll,epoll等本地调用或者类似的操作系统的特定系统调用的封装。


图2-3

创建选择器

将通道注册到选择器上

让选择器监听注册的通道

处理选择器返回的就绪的通道

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容