非阻塞NIO与IO

本文深入探讨了NIO与传统IO的区别,详细解释了NIO的三大核心组件:通道(Channel)、选择器(Selector)和缓冲区(Buffer),并介绍了NIO的工作原理及服务器处理流程,帮助读者理解NIO如何提高数据处理效率。
摘要由CSDN通过智能技术生成

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

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值