非阻塞NIO与IO

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)根据不同的事件做不同的处理

猜你喜欢

转载自blog.csdn.net/weixin_38108266/article/details/82831176