Java面试通关手册

Java NIO 概览

2018-05-14  本文已影响3人  Snailclimb

一 NIO简介

Java NIOjava 1.4 之后新出的一套IO接口,这里的的新是相对于原有标准的Java IO和Java Networking接口。NIO提供了一种完全不同的操作方式。

NIO中的N可以理解为Non-blocking,不单纯是New。

它支持面向缓冲的,基于通道的I/O操作方法。 随着JDK 7的推出,NIO系统得到了扩展,为文件系统功能和文件处理提供了增强的支持。 由于NIO文件类支持的这些新的功能,NIO被广泛应用于文件处理。

二 NIO的特性/NIO与IO区别

Java NIO基本组件如下

1 Channels and Buffers(通道和缓冲区)

IO是面向流的,NIO是面向缓冲区的

2 Non-blocking IO(非阻塞IO)

IO流是阻塞的,NIO流是不阻塞的

3 Selectors(选择器)

NIO有选择器,而IO没有。

三 读数据和写数据方式

通常来说NIO中的所有IO都是从 Channel(通道) 开始的。

从通道进行数据读取 :创建一个缓冲区,然后请求通道读取数据。

从通道进行数据写入 :创建一个缓冲区,填充数据,并要求通道写入数据。

数据读取和写入操作图示:

数据读取和写入操作图示

四 NIO核心组件简单介绍

NIO包含下面几个核心的组件:

整个NIO体系包含的类远远不止这三个,只能说这三个是NIO体系的“核心API”。

通道

在Java NIO中,主要使用的通道如下(涵盖了UDP 和 TCP 网络IO,以及文件IO):

缓冲区

在Java NIO中使用的核心缓冲区如下(覆盖了通过I/O发送的基本数据类型:byte, char、short, int, long, float, double ,long):

选择器

Java NIO提供了“选择器”的概念。这是一个可以用于监视多个通道的对象,如数据到达,连接打开等。因此,单线程可以监视多个通道中的数据。

如果应用程序有多个通道(连接)打开,但每个连接的流量都很低,则可考虑使用它。 例如:在聊天服务器中。

下面是一个单线程中Slector维护3个Channel的示意图:

线程使用选择器来处理3个通道

要使用Selector的话,我们必须把Channel注册到Selector上,然后就可以调用Selector的select()方法。这个方法会进入阻塞,直到有一个channel的状态符合条件。当方法返回后,线程可以处理这些事件。

参考:

官方JDK相关文档

谷歌搜索排名第一的Java NIO教程

Java NIO 与 IO之间的区别

《Java程序员修炼之道》

上一篇 下一篇

猜你喜欢

热点阅读