标题手段Java NIO该分散体浓缩
Java NIO内置支持分散与收集。的概念主要用于信道分散聚集的读写。
读出的分散体的一个通道被读多个数据buffer在。因此。数据分散到多个buffer中。
对一个通道的集中写就是将数据从多个buffer中写到一个通道中。因此。通道从多个buffer将数据收集到一个通道中。
分散收集经经常使用于对数据传输分开处理的场景。
比方,一条消息由header和body构成,你须要将header和body保存在不同的buffer中。
这样做就是的对header和body分开处理更加简单了。
分散读取
看一个样例:
注意buffer是怎样插入到数组中的,以及数组作为參数传递给了channel.read方法。read方法从channel中取出数据,依照buffer数组中buffer的顺序将数据写入,一个满了。就会顺序写到下一个buffer中。
其实,分散读取在移动到下一个buffer前会先填充满一个buffer,意味着这样的方式不适合消息大小动态变化的情况。
换言之,假设你有一个header和body,然后header是固定大小的(比方:128字节),这样的情况,分散读取就能发挥的非常好。
集中写
注意:Buffer的flip方法调用
buffer数组作为參数传递给write方法,将buffer的内容依照顺序写入通道。
仅仅处于position和limit之间的数据才会写入。
因此,假设一个buffer有128字节的容量。可是仅仅有58字节的内容,那么仅仅有58字节会写入通道中。所以。和分散读取相比。集中写对于消息大小不固定的处理会更好。