原文连接:http://tutorials.jenkov.com/java-nio/nio-vs-io.html
Java NIO和IO的主要区别
下面的表格总结了Java NIO和IO的主要区别
IO | NIO |
面向流 | 面向缓冲区 |
阻塞IO | 非阻塞IO、选择器 |
面向流和面向缓冲区的比较
Java IO是面向流的意味着你一次能够从输入流读取一个或者多个字节。怎么处理这些字节由你决定。它们并没有缓存到任何位置.更进一步讲,你不能在一个输入流的数据中向前或者向后移动。如果你需要在输入流的数据中向前或者向后移动,你需要先将他们缓存起来。
Java NIO的缓冲区有些微小的不一样。数据被读入到一个缓冲区中等待处理。你可以根据需要在缓冲区的数据中向前向后移动。这使得你在处理数据时拥有更大的弹性。无论怎样,你还是需要检查缓冲区中是否有你需要的所有数据。而且,你还要确保新读入的数据不会覆盖你还没有处理的数据。
阻塞IO和非阻塞IO
java IO的各种各样的流都是阻塞的。这意味着,当一个线程调用了read()和write()方法,这个线程就会被阻塞,直到有数据可以读或者所有数据被被写完。在这期间,这个线程什么也干不了。
java NIO的非阻塞的模式使得一个线程能够读取通道中当前有的数据。如果通道中当前没有数据,就什么都不读取,而不是一直阻塞等到有数据可读。期间这个线程可以处理一些其他的事情。非阻塞写也是同样的道理。一个线程能够请求将一些数据写入到通道中,但是不用等着所有的数据都写完,这个线程就可以继续去做其他的事情。
非阻塞IO在等待IO调用的的空闲时间里通常会对其他的通道执行IO操作。也就是说,一个线程通常会管理多个输入、输出通道。
选择器
java NIO的选择器允许一个单线程去监视多个输入通道。你能够使用一个选择器注册多个通道,然后使用一个单线程来选择这些通道中有数据可供读取的,或者选择这些通道中可供写入数据的。这个选择器的机制使得单线程管理多个通道变得容易。