NIO不同于传统的IO,它是在jdk1.4之后引入的,它有如下特性 基于buffer和channel实现面向缓存区的而非流的高性能IO 缓存区可以在堆外创建直接缓存区和非直接堆缓冲区 字节节缓冲区可以通过将文件的一个区域直接映射到内存MappedByteBuffer中 NIO结合了操作系统的新特性,引入了非阻塞Selectors多路复用技术 NIO主要有如下几个部分构成: Buffers存放数据的容器,buffer就像装货的箱子,而货是byte数据。 Charsets Unicode到字节的编解码 Channels application 和相关io之间的连接,就像传输带,buffer在上面传递 Selectors 和 selection keys,和相关的selectable channels提供了非阻塞Selectors多路复用技术