『Java I/O』JavaNIO三大核心原理(图解)

NIO三大核心原理示意图

相关视频参考(来自动力节点):https://www.bilibili.com/video/BV1uq4y1j7Kv

相关资料下载:http://www.bjpowernode.com/?csdn

NIO 有三大核心部分:Channel( 通道) ,Buffer( 缓冲区), Selector( 选择器)

1.Buffer缓冲区

缓冲区本质上是一块可以写入数据,然后可以从中读取数据的内存。这块内存被包装成NIO Buffer对象,并提供了一组方法,用来方便的访问该块内存。相比较直接对数组的操作,Buffer API更加容易操作和管理。

2.Channel(通道)

Java NIO的通道类似流,但又有些不同:既可以从通道中读取数据,又可以写数据到通道。但流的(input或output)读写通常是单向的。 通道可以非阻塞读取和写入通道,通道可以支持读取或写入缓冲区,也支持异步地读写。

3.Selector选择器

Selector是 一个Java NIO组件,可以能够检查一个或多个 NIO 通道,并确定哪些通道已经准备好进行读取或写入。这样,一个单独的线程可以管理多个channel,从而管理多个网络连接,提高效率

『Java I/O』JavaNIO三大核心原理(图解)_第1张图片

 

  •     每个 channel 都会对应一个 Buffer
  •     一个线程对应Selector , 一个Selector对应多个 channel(连接)
  •     程序切换到哪个 channel 是由事件决定的
  •     Selector 会根据不同的事件,在各个通道上切换
  •     Buffer 就是一个内存块 , 底层是一个数组
  •     数据的读取写入是通过 Buffer完成的 , BIO 中要么是输入流,或者是输出流, 不能双向,但是 NIO 的 Buffer 是可以读也可以写。
  •     Java NIO系统的核心在于:通道(Channel)和缓冲区 (Buffer)。通道表示打开到 IO 设备(例如:文件、 套接字)的连接。若需要使用 NIO 系统,需要获取 用于连接 IO 设备的通道以及用于容纳数据的缓冲 区。然后操作缓冲区,对数据进行处理。简而言之,Channel 负责传输, Buffer 负责存取数据

你可能感兴趣的:(JavaNIO,java,JavaNIO,nio,io流,后端)