NIO和IO对比

##1.NIO和IO区别
IO:以流为导向,阻塞IO。以Stream为导向
NIO:以缓冲区为导向,非阻塞IO,Buffer为导向,Selector选择器。

####阻塞IO是如何处理数据的呢?
先读取准备好的数据,等读取完,再读取下一条数据,以串行模式为主。

####而NIO是以Buffer(缓冲区),Thread(线程),Channel(通道)还有Selector(选择器)为配合而成,通常Channer会注册到Selector中,开始,Thread先把数据读取进Channel,然后Channel会把数据填充进Buffer,如果Channel要进行,那必须需要先通过Selector.selector(),然后会得到selectionkey的一个集合,通过这个集合可以了解哪个Channel读取了数据,在填充了数据之后,会进行检查数据,再处理数据,之后再循环操作,本质上还是串行模式。
但好处是只会在Channel有数据时读取,即时阻塞也只会阻塞在Selector.selector()。

NIO和IO对比
NIO和IO对比

###为什么读写分离会好一点?
计算机有一个网卡,网络的数据通过网卡读取或者输出,而网卡的读取是分离的,如果在上层也进行读取分离,那么在可拓展IO的带宽,更有利于数据的传输。