(一)Netty之nio三大组件

Netty之nio三大组件



一、nio概念

non(new)- blocking io 非阻塞IO,是jdk1.4后新增的api,主要面向缓冲区的。

二、nio三大组件

1.Channel

channel是读写数据的双向通道。可以从channel将数据读入buffer,也可以将buffer的数据写入channel。

常见的Channel有

  • FileChannel —— 文件处理时的数据传输通道
  • DatagramChannel —— UDP网络编程时的数据传输通道
  • SocketChannel —— TCP网络编程时的数据传输通道,用于服务器端
  • ServerSocketChannel —— TCP网络编程时的数据传输通道,客户端和服务器端都可用

2.Buffer

buffer是内存缓冲区,暂存从channel中读写的数据

常见的Buffer有

  • ByteBuffer —— 以字节为单位缓冲数据,抽象类
    • MappedByteBuffer
    • DirectBuffer
    • HeapByteBuffer
  • ShortBuffer*
  • IntBuffer
  • LongBuffer
  • FloatBuffer
  • DoubleBuffer

3.Selector

selector是多路复用器,它的作用就是配合一个线程不断轮询多个channel,获取这些channel上发生的事件,Selector可以监听的状态有:Connect(客户端连接成功后)、Accept(准备好进行连接)、Read(可读)、Write(可写),当监听到某一Channel的某个状态时,才允许对Channel进行相应的操作。

selector的select()会阻塞直到channel发生了读写就绪事件,然后select()方法会返回这些事件交给thread处理。fileChannel因为是阻塞式的,所以无法使用selector。
在这里插入图片描述
这些channel工作在非阻塞模式下,不会让线程吊死在一个channel上,适合连接数多但流量低的场景(low traffic)


总结

Java NIO系统的核心在于:通道(Channel)和缓冲区(Buffer)。通道表示打开到 IO 设备(文件、套接字)的连接。若使用 NIO 系统,需要获取用于连接 IO 设备的通道以及用于容纳数据的缓冲区,然后操作缓冲区,对数据进行处理。

总体而言,通过Selector配合一个线程来管理多个通道,而通道负责传输,缓冲区负责存储。

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值