NIO与IO的区别:
(1)NIO以块的方式处理数据,IO以字节流的形式写入和读出。因此NIO的效率比IO的效率高很多。
(2)NIO采用通道和缓冲区的形式来进行处理数据的。它的通道是双向的,但是IO中的流是单向的。
通道Channel:
Channel是对IO包中的流的模拟。通过它可以对数据进行读取和写入,到任何目的地或者来自任何地方的所有数据都必须通过一个channel对象。通道就像是流。
选择器Selector:
允许一个单独的线程监视多个通道,可以在一个选择器上注册多个通道,使用一个单独的线程来选择通道。一个线程管理多个连接
缓冲区Buffer:
Buffer实际上是一个容器对象,发送给一个通道的所有对象都必须放到缓冲区中,它包含一些要写入或者刚读出的数据,在写入数据时,是将数据写入缓冲区,任何时候访问NIO中的数据,都是将它放到缓冲区中。
缓冲区实质上是一个数组,通常是一个字节数组,也可以使用其他种类的数组,但它不仅仅是一个数组,它提供了对数据的结构化访问,还可以跟踪系统的读/写进程。
缓冲区的类型:
ByteBuffer CharBuffer ShortBuffer IntBuffer LongBuffer FloatBuffer DoubleBuffer
参考:https://blog.csdn.net/qq_36520235/article/details/81318189
NIO的工作原理:
使用NIO读取数据的三个步骤:
1)FileInputStream中获取Channel
2)创建Buffer
3)将数据从Channel中写入Buffer
编写服务器处理程序:
1)向Selector对象注册感兴趣的事件
2)从Selector中获取感兴趣的事件
3)根据不同的事件做不同的处理