概述

  Java NIO 是 JDK 1.4 发布的一套全新的IO API(New IO 简称 NIO),由于 JDK 1.7 对 NIO 的更新,目前 NIO 被广泛应用,以至于

将 JDK 1.7 的改动称为 NIO.2,NIO 可以替代传统的Java IO API。NIO与原来的IO有同样的作用和目的,但是使用方式及原理有很大

不同。NIO支持面向缓冲区的、基于通道的IO操作。并且,NIO将以更加高效的方式进行文件的读写操作

1.Java NIO与IO的主要区别

  2.Java NIO 简介

1.1.传统的I/O(数据传输:文件、网络)

  使用传统的I/O程序读取文件内容, 并写入到另一个文件(或Socket),会有较大的性能开销

  2.Java NIO 简介

  1) 先将文件内容从磁盘中拷贝到操作系统buffer

  2) 再从操作系统buffer拷贝到程序应用buffer

  3) 从程序buffer拷贝到socket buffer

  4) 从socket buffer拷贝到协议引擎.

1.2.NIO

  NIO技术省去了将操作系统的read buffer拷贝到程序的buffer, 以及从程序buffer拷贝到socket buffer的步骤, 直接将 read buffer

拷贝到 socket buffer,javaFileChannel.transferTo() 方法就是这样的实现, 这个实现是依赖于操作系统底层的sendFile()实现的.

  2.Java NIO 简介

NIO 即 non-blocking IO,是一种非阻塞式的 IO,NIO 三大核心部分:Channel(通道),Buffer(缓冲区), Selector(选择器)

1.通道和缓冲区:Java NIO系统的核心在于:通道(Channel)和缓冲区(Buffer)

  通道表示打开到 IO 设备(例如:文件、套接字)的连接。若需要使用 NIO 系统,需要获取用于连接 IO 设备的通道以及用于

容纳数据的缓冲区。然后操作缓冲区,对数据进行处理(通道只是用于获取连接,数据由Buffer传输

  简而言之,Channel 负责传输(铁路), Buffer 负责存储(火车)

 

  

 

  

  

  

 

 

 

 

  

 

  

  

  

  

相关文章: