Java IO与NIO
2017-08-31 20:49
190 查看
我们知道在计算机里,各设备的运行速度CPU是最快的,其次是内存,再而是硬盘,CPU > 内存 > 硬盘。然而解释IO就可以这样比喻:I 就是从硬盘到内存input,O就是从内存到硬盘output。从硬盘读取数据,有2种方式:
第一种,程序一直等待,直到数据读取完后,再继续操作。这种方式最简单,叫阻塞IO。
第二种,程序继续往下执行,等到数据读取完后,通知当前程序(对硬件来说这叫中断,对程序来说叫回调)。然后程序可以立即处理数据,也可以执行完当前操作再读取数据。
在以前的Java IO中,都是阻塞IO;直到jdk1.4才引入了NIO,NIO即New IO,它是对IO的补充,NIO和IO有相同的作用和目的,但实现方式不同,NIO主要用到的是块,所以NIO的效率要比IO高很多。在Java API中提供了两套NIO,一套是针对标准输入输出NIO,另一套就是网络编程NIO。宏观看Java IO和NIO之间的主要区别:
1、面向流与面向缓冲
Java IO和NIO之间第一个最大的区别是,IO是面向流的,NIO是面向缓冲区的。 Java IO面向流意味着每次从流中读一个或多个字节,直至读取所有字节,它们没有被缓存在任何地方。此外,它不能前后移动流中的数据。如果需要前后移动从流中读取的数据,需要先将它缓存到一个缓冲区。 Java NIO的缓冲导向方法略有不同。数据读取到一个它稍后处理的缓冲区,需要时可在缓冲区中前后移动。这就增加了处理过程中的灵活性。但是,还需要检查是否该缓冲区中包含所有您需要处理的数据。而且,需确保当更多的数据读入缓冲区时,不要覆盖缓冲区里尚未处理的数据。
2、阻塞与非阻塞IO
Java IO的各种流是阻塞的。这意味着,当一个线程调用read() 或 write()时,该线程被阻塞,直到有一些数据被读取,或数据完全写入。该线程在此期间不能再干任何事情了。Java NIO的非阻塞模式,使一个线程从某通道发送请求读取数据,但是它仅能得到目前可用的数据,如果目前没有数据可用时,就什么都不会获取,而不是保持线程阻塞,所以直至数据变的可以读取之前,该线程可以继续做其他的事情。 非阻塞写也是如此。一个线程请求写入一些数据到某通道,但不需要等待它完全写入,这个线程同时可以去做别的事情。
线程通常将非阻塞IO的空闲时间用于在其它通道上执行IO操作,所以一个单独的线程现在可以管理多个输入和输出通道(channel)。
3、选择器(Selectors)
Java NIO的选择器允许一个单独的线程来监视多个输入通道,你可以注册多个通道使用一个选择器,然后使用一个单独的线程来“选择”通道:这些通道里已经有可以处理的输入,或者选择已准备写入的通道。这种选择机制,使得一个单独的线程很容易来管理多个通道。
第一种,程序一直等待,直到数据读取完后,再继续操作。这种方式最简单,叫阻塞IO。
第二种,程序继续往下执行,等到数据读取完后,通知当前程序(对硬件来说这叫中断,对程序来说叫回调)。然后程序可以立即处理数据,也可以执行完当前操作再读取数据。
在以前的Java IO中,都是阻塞IO;直到jdk1.4才引入了NIO,NIO即New IO,它是对IO的补充,NIO和IO有相同的作用和目的,但实现方式不同,NIO主要用到的是块,所以NIO的效率要比IO高很多。在Java API中提供了两套NIO,一套是针对标准输入输出NIO,另一套就是网络编程NIO。宏观看Java IO和NIO之间的主要区别:
IO | NIO |
面向流 | 面向缓冲 |
阻塞IO | 非阻塞IO |
无 | 选择器 |
Java IO和NIO之间第一个最大的区别是,IO是面向流的,NIO是面向缓冲区的。 Java IO面向流意味着每次从流中读一个或多个字节,直至读取所有字节,它们没有被缓存在任何地方。此外,它不能前后移动流中的数据。如果需要前后移动从流中读取的数据,需要先将它缓存到一个缓冲区。 Java NIO的缓冲导向方法略有不同。数据读取到一个它稍后处理的缓冲区,需要时可在缓冲区中前后移动。这就增加了处理过程中的灵活性。但是,还需要检查是否该缓冲区中包含所有您需要处理的数据。而且,需确保当更多的数据读入缓冲区时,不要覆盖缓冲区里尚未处理的数据。
2、阻塞与非阻塞IO
Java IO的各种流是阻塞的。这意味着,当一个线程调用read() 或 write()时,该线程被阻塞,直到有一些数据被读取,或数据完全写入。该线程在此期间不能再干任何事情了。Java NIO的非阻塞模式,使一个线程从某通道发送请求读取数据,但是它仅能得到目前可用的数据,如果目前没有数据可用时,就什么都不会获取,而不是保持线程阻塞,所以直至数据变的可以读取之前,该线程可以继续做其他的事情。 非阻塞写也是如此。一个线程请求写入一些数据到某通道,但不需要等待它完全写入,这个线程同时可以去做别的事情。
线程通常将非阻塞IO的空闲时间用于在其它通道上执行IO操作,所以一个单独的线程现在可以管理多个输入和输出通道(channel)。
3、选择器(Selectors)
Java NIO的选择器允许一个单独的线程来监视多个输入通道,你可以注册多个通道使用一个选择器,然后使用一个单独的线程来“选择”通道:这些通道里已经有可以处理的输入,或者选择已准备写入的通道。这种选择机制,使得一个单独的线程很容易来管理多个通道。
相关文章推荐
- java io 与java nio
- Java中的NIO和IO的对比分析
- Java nio和io
- java.jse--IO--Java NIO与IO的区别和比较
- Java NIO和IO的区别(转)
- Java 8:活好水多——Java 的新IO (nio)
- Java文件读写IO/NIO及性能比较总结
- jAVA IO 以及 NIO 理解
- Java中NIO和IO的比较
- JAVA IO与NIO优劣浅析
- Java IO与NIO
- 彻底明白Java的IO系统 & NIO
- javaIO之NIO
- Java NIO和IO的主要区别
- Java 新IO技术(NIO) JDK1.4
- 【转】Java 网络IO编程总结(BIO、NIO、AIO均含完整实例代码)
- Java 网络IO编程总结(BIO、NIO、AIO均含完整实例代码)
- Java IO: BIO, NIO, AIO(含代码实现)
- NIO简介-Java New IO
- java io bio nio aio 详解