什么是NIO
NIO是相对有BIO而言的,就是非阻塞性IO 。 什么叫非阻塞性 ?我举一个简单的例子:
比如,你客户端发送了一个字符串: nio test 。 考虑到网络底层的传输情况的复杂性,有可能,前一秒服端接受了nio几个字符,过了10ms , 再接收到了test字符串。在BIO中,不会出现这个问题,是因为在调用read方法的时候,方法一直在这里阻塞,在这里一定,如果不发生异常,或者连接中断,它一定会读到流的结束,比如你客户端一次写入了,服务端也会一次读出所有的数据。如果没有读完,线程会一直在这里等待。
但是对于NIo ,在read的时候,他不会一直等等,一次调用read方法,此时,能读到多少数据就返回多少数据,方法是立即返回的,不会在这里阻塞线程 。这个要好好理解。
由于NIO的一次read能读多少就读多少,所以也导致了另外的问题: 粘包和拆包问题。
我举一个简单的例子:
一群人咋肯德基都点了一份汉堡和可乐套餐,由于是现做的,所以需要按顺序排队等待,会出现下面的情况:
- BIO : 所有的人都需要在窗口排队,每做好一个汉堡和可乐套餐,窗口递出来,说了好了,然后端走,到下一个人。
- NIO : 每个人注册一个编号,服务员说,你们不用在窗口等待,好了直接叫号,每个人是可以干别的事情。好了,直接喊一声,10号,10号过去端走他的套餐。有时候,一次做好了,一个汉堡,2分可怜,服务员说,你认识下面一位啊,可以直接带给下一位。这个时候,你拿到的就是 一个汉堡2分可乐。这个时候就是粘包的情况,你需要将你多出来的可乐拆包给下一个。