2023年金三银四招聘:Java NIO简明教程

2023年的金三银四招聘季并没有想象中的激烈。一个朋友在前段时间投了几十家公司,多数申请石沉大海。终于有了面试机会,却在被问到什么是NIO时答不上来。今天,我们将深入了解Java NIO,以帮助大家更好地理解这个概念。
什么是NIO?

Java NIO(Non-blocking Input/Output,非阻塞输入/输出)是Java提供的一种新的I/O处理框架,从Java 1.4开始引入。NIO旨在提高I/O操作的性能和可扩展性。它允许单线程中处理多个I/O操作,从而避免了传统I/O(称为阻塞I/O或BIO)中每个连接需要一个线程的问题。

NIO架构图

image.png

NIO的主要特点包括:

  1. 非阻塞I/O:NIO支持非阻塞I/O操作,这意味着线程可以在等待I/O操作完成的同时执行其他任务。这有助于提高线程的利用率和系统的性能。
  2. 通道(Channel) :通道是连接数据源和目标的主要组件。它允许数据在数据源和目标之间高效地传输。通道可以是文件、套接字等。Channel类似于传统I/O中的流,但它们支持非阻塞操作。
  3. 缓冲区(Buffer) :缓冲区是NIO中用于临时存储数据的容器。它提供了对数据的结构化访问,同时还支持数据的批量操作。在NIO中,所有数据的输入和输出都通过缓冲区进行。
  4. 多路复用器(Selector) :多路复用器是NIO中的一个关键组件,它允许单个线程监听多个通道的I/O事件。当某个通道准备好进行I/O操作时,多路复用器会通知相关线程。这使得一个线程可以处理多个并发连接,从而提高了系统的可扩展性
Channel详解

通道的主要作用是进行数据传输,通常涉及到读取和写入操作。Channel与传统的I/O流有一定相似性,但它们之间也存在一些差异。

  • Channel的双向性:与传统的I/O流不同,Channel通常是双向的,这意味着一个Channel既可以用于读取数据,也可以用于写入数据。然而,也有一些特定类型的Channel只支持单向操作,例如只读或只写。
  • 非阻塞操作:Channel支持非阻塞操作,这是它与传统I/O流的一个显著区别。在非阻塞模式下,Channel不会在执行读取或写入操作时阻塞当前线程。这样可以提高程序的响应速度和性能。

在Java NIO中,通道有以下几种类型:

  • FileChannel:用于文件操作的通道。它支持从文件中读取数据和向文件中写入数据。注意,FileChannel不支持非阻塞操作。
  • SocketChannel:用于套接字连接的通道。它支持TCP连接,并且可以在非阻塞模式下工作。这使得它非常适合实现多路复用的网络通信。
  • ServerSocketChannel:用于服务器套接字的通道。它主要用于监听传入的TCP连接,并在有新连接到达时创建与之对应的SocketChannel。
  • DatagramChannel:用于UDP数据传输的通道。它支持非阻塞操作,可以实现高效的数据报文传输。
  • Channel通常与缓冲区(Buffer)一起使用。缓冲区是一块连续的内存区域,用于存储数据。当数据从Channel读取到缓冲区时,应用程序可以对这些数据进行处理;当数据从缓冲区写入到Channel时,数据会被传输到目标。

image.png

缓冲区(Buffer)详解

缓冲区具有以下特点:

  1. 容量(Capacity):缓冲区的容量表示缓冲区内可以存储的元素数量。容量在缓冲区创建时被指定,并且在缓冲区的整个生命周期中不会发生改变。
  2. 限制(Limit):缓冲区的限制表示第一个不应该读取或写入的元素位置。换句话说,缓冲区内部的有效数据范围是从第一个元素开始到限制位置之前的所有元素。
  3. 位置(Position):缓冲区的位置表示下一个要读取或写入的元素的索引。当读取或写入数据时,位置会随着操作的进行而改变。
  4. 标记(Mark):缓冲区的标记是一个可选的属性,用于记忆特定的位置。通过调用mark()方法,可以将当前位置作为标记。在将来,可以使用reset()方法将位置重置回先前标记的地方。

在Java NIO中,缓冲区有多种类型,它们对应于基本数据类型。例如:

  1. ByteBuffer:存储字节数据的缓冲区。
  2. CharBuffer:存储字符数据的缓冲区。
  3. ShortBuffer:存储短整型数据的缓冲区。
  4. IntBuffer:存储整型数据的缓冲区。
  5. LongBuffer:存储长整型数据的缓冲区。
  6. FloatBuffer:存储浮点数数据的缓冲区。
  7. DoubleBuffer:存储双精度浮点数数据的缓冲区。

缓冲区的主要操作有:

  1. 读取(Read):从缓冲区中获取数据。
  2. 写入(Write):将数据写入缓冲区。
  3. 翻转(Flip):将缓冲区的状态从写入模式切换到读取模式,同时将位置重置为0,并将限制设置为当前位置。
  4. 清空(Clear):清空缓冲区内的数据,将位置重置为0,限制设置为容量。
  5. 压缩(Compact):将未读取的数据移到缓冲区的开头,并将位置设置为未读取数据的末尾,限制设置为容量。

image.png

缓冲区的核心作用是在数据源和目标之间临时存储数据,以便Channel进行读取和写入操作

多路复用器(Selector)

多路复用器(Selector)在Java NIO中起到了关键作用,它能够让单个线程同时管理多个通道,处理各种I/O事件。多路复用器的核心概念是通过在一个线程上轮询通道的事件状态,使得程序可以高效地处理多个通道上的I/O操作。这种设计模式也被称为Reactor模式。

Selector主要负责以下几个方面的功能:

  1. 注册通道:将通道注册到Selector上,使得Selector能够监听这些通道的I/O事件。
  2. 监听事件:Selector会不断轮询所有注册的通道,检测它们的事件状态(例如:是否可读、可写等)。
  3. 通知:当某个通道准备好进行某种I/O操作时,Selector会通知相应的线程。线程随后可以对该通道进行适当的操作,例如:读取、写入等。
  4. 取消注册:当一个通道不再需要被监听时,可以从Selector上取消注册。

image.png

通过使用多路复用器(Selector),我们可以使用较少的线程来处理大量的并发连接,从而提高系统的性能和可扩展性。这对于构建高性能的网络服务和应用程序非常有帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值