NIO简介
一、Java NIO简介
Java New IO Non Blocking IO,从java1.4版本就开始引入了新的IO API,可以替代标准的Java IO API。NIO与原来的IO有同样的作用和目的,但是使用的方式完全不同,NIO支持面向缓冲区的、基于通道的IO操作。NIO将更加高效的方式进行文件的读写操作。
二、Java NIO与IO的区别
IO | NIO |
面向流(Stream Oriented) | 面向缓冲区(Buffer Oriented) |
阻塞IO(Blocking IO) | 非阻塞IO(Non Blocking IO) |
无 | 选择器(Selector) |
三、面向流和面向缓冲区
Java NIO与IO的最大的区别就是:IO是面向流,Java NIO是面向缓冲区的。JAVA IO面向流,就意味着他在进行数据操作的时候直接是把数据流从一个方向到另外一个方向等,不需要操作缓冲区。而JAVA NIO是面向缓冲区的,每次操作数据时需要先处理数据流缓冲区,此时在操作数据流缓冲区的时候是可以对数据流进行移动操作的(Bufer允许左右移动数据流读取的位置等)。当缓冲区数据到达了一定的条件时,才开始采取数据流向。
Java IO数据流操作是单向的,而Java NIO数据操作允许数据双向的。
Java NIO
- 阻塞IO与非阻塞IO:
Java IO阻塞是指当一个线程在write或read操作时,该线程被阻塞,不可以做其他任何操作,直到write或read操作完成后,该线程才可以继续做其他操作。Java NIO非阻塞模式是指当一个线程通过通道(Channel)发送请求读去数据时,此时它仅可以获取目前可读的数据,如果没有可用数据,此时就什么也不获取,而不保持线程阻塞。
非阻塞写也一样:一个线程请求写入一些数据到某通道,但不需要等待它完全写入,这个线程同时可以去做别的事情。
线程通常将非阻塞IO的空闲时间用于在其它通道上执行IO操作,所以一个单独的线程现在可以管理多个输入和输出通道(channel)。
- 通道与缓冲区
Java NIO系统的核心:通道(Channel)和缓冲区(Buffer)。通道表示打开到IO设备的连接。若需要使用NIO系统,需要获取用于连接IO设备的通道以及用于容纳数据的缓冲区,然后操作缓冲区,对数据进行处理。
通道(Channel):负责数据传输
缓冲区(Buffer):负责数据存储